JS复制内容到剪贴板(writeText‘ of undefined)

在 Chrome 的 DevTools 控制台下执行 navigator.clipboard 返回 undefined,经查找资料发现是浏览器禁用了非安全域的 navigator.clipboard 对象,哪些地址是安全的呢?

安全域包括本地访问与开启TLS安全认证的地址,如 https 协议的地址、127.0.0.1 或 localhost 。

所以本文就是作一个兼容写法,在安全域下使用 navigator.clipboard 提升效率,非安全域退回到 document.execCommand('copy'); 保证功能可用。

fastadmin框架:

//复制功能
            $("#copy").on('click',function (){
                const copyText = document.getElementById("c-number");
                copyText.select();
                // copyText.setSelectionRange(0, 99999);
                // document.execCommand('copy');
                handleCopyValue(copyText.value)
                    .then(() => {
                        Backend.api.toastr.success('房源编号复制成功');
                    })
                    .catch(() => {
                        Backend.api.toastr.error('自动复制失败,请手动复制');
                    });
            });
function handleCopyValue(text) {
        //浏览器禁用了非安全域的 navigator.clipboard 对象
        //在线上环境会报错 TypeError: Cannot read properties of undefined (reading 'writeText')
        if (!navigator.clipboard && window.isSecureContext) {
          return navigator.clipboard.writeText(text)
        } else {
          // 判断是否支持拷贝
          if (!document.execCommand('copy')) return Promise.reject()
          // 创建标签,并隐藏
          const textArea = document.createElement('textarea')
          textArea.style.position = 'fixed'
          textArea.style.top = textArea.style.left = '-100vh'
          textArea.style.opacity = '0'
          textArea.value = text
          document.body.appendChild(textArea)
          // 聚焦、复制
          textArea.focus()
          textArea.select()
          return new Promise((resolve, reject) => {
            // 不知为何,必须写这个三目,不然copy不上
            document.execCommand('copy') ? resolve() : reject()
            textArea.remove()
          })
        }
      }

引用文档:https://blog.csdn.net/zero77ld/article/details/127967854

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Streamlit中运行JavaScript并将内容复制剪贴板,你可以使用streamlit-components库中的Clipboard组件。 首先,你需要安装streamlit-components库: ``` pip install streamlit-component-lib ``` 然后,创建一个名为`clipboard.js`的JavaScript文件,其中包含以下代码: ``` import {useState, useEffect} from "react"; import {Button} from "antd"; function Clipboard(props) { const [copySuccess, setCopySuccess] = useState(""); function copyText(){ navigator.clipboard.writeText(props.copyText); setCopySuccess("已复制剪贴板!"); }; useEffect(() => { let timeout; if (copySuccess !== "") { timeout = setTimeout(() => { setCopySuccess(""); }, 3000); } return () => { clearTimeout(timeout); }; }, [copySuccess]); return ( <div> <Button onClick={copyText}>{props.buttonText}</Button> {copySuccess} </div> ); } ``` 这个代码包含一个名为`Clipboard`的React组件。它将使用`navigator.clipboard.writeText`函数将文本复制剪贴板,并显示一个成功消息。 接下来,创建一个名为`clipboard.py`的Python文件,其中包含以下代码: ``` import streamlit.components.v1 as components Clipboard = components.declare_component( "Clipboard", url="http://localhost:3001", ) def clipboard(copyText: str, buttonText: str): return Clipboard(copyText=copyText, buttonText=buttonText, key=1) ``` 这个代码使用`components.declare_component`函数声明名为`Clipboard`的组件,并将其URL设置为`http://localhost:3001`(这是组件的默认URL)。 最后,在Streamlit应用程序中,你可以使用以下代码来使用`clipboard`函数: ``` import clipboard text_to_copy = "Hello, world!" button_text = "复制剪贴板" if clipboard.clipboard(text_to_copy, button_text): st.success("已复制剪贴板!") ``` 这个代码将使用`clipboard`函数来创建一个复制文本到剪贴板的按钮,并在成功时显示一个消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值