在日常业务开发,比如复制后增加版权信息,点击复制,等场景中需要进行复制粘贴的操作,以下是几种实现方案。
Clipboard API
Clipboard API 提供了响应剪贴板命令(剪切、复制和粘贴)与异步读写系统剪贴板的能力。从权限 API (Permissions API) 获取权限之后,才能访问剪贴板内容;如果用户没有授予权限,则不允许读取剪贴板内容。
可以使用全局的 Navigator.clipboard 来访问剪贴板。
Navigator.clipboard 属性返回 Clipboard 对象,所有操作都通过这个对象进行。
Clipboard 对象提供了四个方法,用来读写剪贴板。它们都是异步方法,返回 Promise 对象。
read( ) 方法
read()方法可以从剪贴板读取任意数据,可以是文本数据,也可以是二进制数据(比如图片)。该方法需要用户明确给予许可。
read()方法返回一个Promise对象。一旦该对象的状态变为resolved,就可以获得一个数组,每个数组成员都是ClipboardItem对象的实例。
ClipboardItem对象表示一个单独的剪贴项,每个剪贴项都拥有types属性和getType( )方法。
ClipboardItem.types属性返回一个数组,里面的成员是该剪贴项可用的MIME类型,比如某个剪贴项可以用HTML格式粘贴,也可以用纯文本格式粘贴,那么它就有两个MIME类型(text/html和text/plain)。
ClipboardItem.getType(type)方法用于读取剪贴项的数据,返回一个Promise对象。该方法接受剪贴项的MIME类型作为参数,返回该类型的数据,该参数是必需的,否则会报错。
示例:
//获取权限navigator.permissions .query({name:clipboard-read}) .then(result=>{if(result.state ==granted|| result.state ==prompt) {//读取剪贴板navigator.clipboard.read().then(data=>{console.log(data) }) }else{ alert(请允许读取剪贴板!) } })readText( ) 方法
readText()方法可以从剪贴板读取文本内容。该方法需要用户明确给予许可。
示例:
//获取权限navigator.permissions .query({name:clipboard-read}) .then(result=>{if(result.state ==granted|| result.state ==prompt) {//读取剪贴板navigator.clipboard.readText().then(text=>{console.log(text) }) }else{ alert(请允许读取剪贴板!) } })write( ) 方法
write()方法可以将任意数据写入剪贴板,可以是文本数据,也可以是二进制数据。该方法不需要用户许可。
write()方法接受一个ClipboardItem实例作为参数,表示写入剪贴板的数据。
示例:
//写入一张图片constimgURL =https://www.gtxsd.com/wp-content/uploads/2023/03/300.pngconstdata =awaitfetch(imgURL)constblob =awaitdata.blob()awaitnavigator.clipboard.write([newClipboardItem({ [blob.type]: blob }) ])注意,Chrome 浏览器目前只支持写入 PNG 格式的图片。
writeText( ) 方法
writeText()方法可以写入文本内容至剪贴板。该方法不需要用户许可。
示例:
navigator.clipboard.writeText(写入剪贴板文本内容)安全限制
由于用户可能把敏感数据(比如密码)放在剪贴板,允许脚本任意读取会产生安全风险,所以这个 API 的安全限制比较多。
首先,Chrome 浏览器规定,只有 HTTPS 协议的页面才能使用这个 API。不过,开发环境(localhost)允许使用非加密协议。
其次,调用时需要明确获得用户的许可。权限的具体实现使用了Permissions API,跟剪贴板相关的有两个权限:clipboard-write(写权限)和clipboard-read(读权限)。写权限自动授予脚本,而读权限必须用户明确同意给予。也就是说,写入剪贴板,脚本可以自动完成,但是读取剪贴板时,浏览器会弹出一个对话框,询问用户是否同意读取。
Document.execCommand()
这个 API 已弃用,不推荐使用它,但是为了兼容还是了解一下吧。
document.execCommand()方法用于操纵可编辑区域的内容。
document.execCommand(copy)
document.execCommand(copy)实现复制操作
示例:
<inputid="copyContent"value="需要被复制内容"><buttonid="copyBtn">点我复制免责声明:内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,本网站所提供的信息只供参考之用。