原生 js 实现点击按钮复制文本
转载自 https://www.cnblogs.com/wisewrong/p/7473978.html
最近遇到一个需求,需要点击按钮,复制 <p> 标签中的文本到剪切板
之前做过复制输入框的内容,原以为差不多,结果发现根本行不通
尝试了各种办法,最后使了个障眼法,实现了下面的效果

一、原理分析
浏览器提供了 copy 命令 ,可以复制选中的内容
document.execCommand("copy")
如果是输入框,可以通过 select() 方法,选中输入框的文本,然后调用 copy 命令,将文本复制到剪切板
但是 select() 方法只对 <input> 和 <textarea> 有效,对于 <p> 就不好使
最后我的解决方案是,在页面中添加一个 <textarea>,然后把它隐藏掉
点击按钮的时候,先把 <textarea> 的 value 改为 <p> 的 innerText,然后复制 <textar

本文介绍了如何使用原生JavaScript实现点击按钮复制文本的功能。由于浏览器提供的`copy`命令只能复制选中的`<input>`和`<textarea>`内容,因此作者采取了一个技巧,即在页面中创建一个隐藏的`<textarea>`,将`<p>`标签的文本内容赋值给`<textarea>`,然后调用`copy`命令,实现在多个浏览器上的兼容性。
最低0.47元/天 解锁文章
4533

被折叠的 条评论
为什么被折叠?



