【JavaScript】复制文本到剪切板

简介: Clipboard API是现代浏览器提供的一组JavaScript接口,用于访问和操作用户剪贴板中的内容。它提供了异步读取和写入剪贴板的功能,可以处理多种类型的数据,如文本、图像等。通过使用navigator.clipboard对象,开发者可以调用相关方法来读取和写入剪贴板中的内容。

一、Clipboard API

Clipboard API是现代浏览器提供的一组JavaScript接口,用于访问和操作用户剪贴板中的内容。它提供了异步读取和写入剪贴板的功能,可以处理多种类型的数据,如文本、图像等。通过使用navigator.clipboard对象,开发者可以调用相关方法来读取和写入剪贴板中的内容。

相关属性方法

属性:

  • clipboardData:表示剪贴板中的数据对象。
  • types:返回剪贴板中数据的类型列表。

方法:

  • readText():异步读取剪贴板中的文本内容。
  • writeText(text):异步将文本内容写入剪贴板。
  • read():异步读取剪贴板中的数据对象。
  • write(data):异步将自定义数据对象写入剪贴板。

示例

constcopyText= () => {
consttext="Hello, Clipboard API!";
navigator.clipboard.writeText(text)
    .then(() => {
console.log("Text copied to clipboard");
    })
    .catch((error) => {
console.error("Failed to copy text: ", error);
    });
}

二、document.execCommand

document.execCommand()是一个旧的浏览器API,用于执行命令并影响浏览器行为。其中包括一些与剪贴板相关的命令,如复制、粘贴等。通过调用document.execCommand('copy')document.execCommand('paste')等命令,可以实现对剪贴板内容进行读取或写入。

constcopyText= () => {
consttext="Hello, Clipboard!"consttextarea=document.createElement('textarea')
textarea.value=texttextarea.style.position='absolute'textarea.style.opacity='0'document.body.appendChild(textarea)
textarea.select()
document.execCommand('copy')
document.body.removeChild(textarea)
};

优点

  • 使用简单,无需额外引入API。
  • 兼容性好。

缺点

  • 功能相对有限,只能处理文本类型的数据。
  • 不支持异步操作。
  • 安全性和用户隐私保护较差。

需要注意的是,document.execCommand()在现代浏览器中已经被废弃,不再推荐使用。而Clipboard API是未来发展的趋势,提供了更好的功能和安全性。因此,在支持Clipboard API的浏览器中,建议使用Clipboard API来进行剪贴板操作。对于不支持Clipboard API的浏览器,可以使用document.execCommand()作为降级方案。

三、useClipboard

  1. 检测浏览器是否支持navigator.clipboard
constisClipboardSupported= () => {
return!!navigator.clipboard&&typeofnavigator.clipboard.writeText==='function';
};
  1. 创建一个名为fallbackCopyText的函数,用于在不支持Clipboard API的浏览器中实现复制功能:
constfallbackCopyText= (text) => {
consttextarea=document.createElement('textarea')
textarea.value=texttextarea.style.position='absolute'textarea.style.opacity='0'document.body.appendChild(textarea)
textarea.select()
document.execCommand('copy')
textarea.remove()
};
  1. 在自定义hooks中,根据浏览器是否支持Clipboard API来选择使用哪种复制方式:
constuseClipboard= () => {
constcopied=ref(false);
constcopyText= (text) => {
if (isClipboardSupported()) {
navigator.clipboard.writeText(text)
        .then(() => {
copied.value=true;
        })
        .catch((error) => {
console.error("Failed to copy text: ", error);
        });
    } else {
fallbackCopyText(text);
copied.value=true;
    }
  };
return { copied, copyText };
};

通过以上降级方案,我们首先检测浏览器是否支持navigator.clipboard。如果支持,则使用navigator.clipboard.writeText()来复制文本。如果不支持,则调用fallbackCopyText()函数来实现复制功能。

在使用自定义hooks的Vue组件中,无需更改任何代码,因为自定义hooks已经处理了浏览器兼容性问题。无论浏览器是否支持Clipboard API,都可以正常使用复制功能。

降级方案中的fallbackCopyText()函数使用了document.execCommand('copy')来执行复制操作。这是一种旧的方式,在现代浏览器中仍然有效,但并不推荐使用。因此,在支持Clipboard API的浏览器中,尽量优先使用navigator.clipboard.writeText()来实现复制功能。

目录
打赏
0
0
0
0
1
分享
相关文章
JavaScript复制内容到剪切板 带格式的复制
JavaScript复制内容到剪切板 带格式的复制
130 0
|
4月前
|
js 特殊文本的判断
js 特殊文本的判断
54 0
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
120 1
文本,Pinia的使用,(0 , _stores_token_js__WEBPACK_IMPORTED_MODULE_1__.useTokenStore),接口中必须用引入store.js文件
文本,Pinia的使用,(0 , _stores_token_js__WEBPACK_IMPORTED_MODULE_1__.useTokenStore),接口中必须用引入store.js文件
文本vitepress,如何设置背景图,如何插入背景图,如何插入logo,为了放背景图片,我们要新建pubilc的文件夹,插入logo要在config.js中进行配置,注意细节,在添加背景时,注意格式
文本vitepress,如何设置背景图,如何插入背景图,如何插入logo,为了放背景图片,我们要新建pubilc的文件夹,插入logo要在config.js中进行配置,注意细节,在添加背景时,注意格式
文本,vitepress的使用,如何使用vitevitepress没有config.js该怎么办?这里使用vitepress进行手动配置,参考只爭朝夕不負韶華的文章
文本,vitepress的使用,如何使用vitevitepress没有config.js该怎么办?这里使用vitepress进行手动配置,参考只爭朝夕不負韶華的文章
JS实现一键点击按钮复制文本
【5月更文挑战第6天】JS实现一键点击按钮复制文本
JavaScript 计算颜色的相对亮度,并确定相应的文本颜色
JavaScript 计算颜色的相对亮度,并确定相应的文本颜色
97 0

热门文章

最新文章

  • 1
    当面试官再问我JS闭包时,我能答出来的都在这里了。
    40
  • 2
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    27
  • 3
    Node.js 中实现多任务下载的并发控制策略
    32
  • 4
    【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
    26
  • 5
    【JavaScript】深入理解 let、var 和 const
    49
  • 6
    【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
    47
  • 7
    【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
    54
  • 8
    【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
    57
  • 9
    如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
    72
  • 10
    【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
    55