JS 实现一键复制功能

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS 实现一键复制功能相关的知识,希望对你有一定的参考价值。

参考技术A

复制是一个使用频率特别高的操作,在网页中,一般可以选中要复制的内容,使用快捷键ctrl+c 将内容复制到剪贴板。除了使用系统提供的快捷方式复制网页内容,我们还可以用JS实现复制,这得益于document的execCommand(\'copy\') 命令。

我们可以通过表单元素的select()方法选中内容,表单元素因为textarea限制少于input,所以推荐使用textarea。我们可以动态创建一个textarea元素,将textarea的value属性值设置为上面的innerText属性值,再执行textarea的select方法选中。

上面实现了选中,下面就可以实现复制功能了。

最后一步就可以用execCommand(\'copy\')实现复制了,它可以复制浏览器中选中的文本,比如说上面被textarea选中的文本,复制之后记得移除textarea。

第二步和第三步可以优化一下,创建一个copy函数,函数参数设置为第一步需要复制的文本,返回值为复制的结果。

完整JS示例如下:

使用示例
可以将上面的完整JS示例写入一个JS文件,将JS文件引入html中,通过JS点击事件来执行复制函数。

小程序 - 实现一键复制功能

小程序 - 实现【一键复制】功能

为啥想起使用【一键复制】功能?因为个人小程序里,不许加外链接,很是头疼,就想到一键复制链接,这是我刚写的一个减一的小程序:

使用【一键复制】:

  • wxml 文件:
<view>
官网:<text selectable=\'true\' bindlongtap=\'copy\' >{{url}}</text>
<!-- 注意,上面只是一个提示功能 -->

<button bindtap="copyBtn">一键复制</button>

</view>


  • js 文件:
//获取到小程序实例
const app = getApp()

Page({
  data: {
    //真正拷贝的数据
    url: "https://xpwi.github.io/shike/"
},

 copyBtn: function (e) {
    var that = this;
    wx.setClipboardData({
      //去找上面的数据
      data: that.data.url,
      success: function (res) {
        wx.showToast({
          title: \'复制成功\',
        });
      }
    });
  }


})

以上是关于JS 实现一键复制功能的主要内容,如果未能解决你的问题,请参考以下文章

js插件实现一键复制功能

js实现一键复制功能

Dreamweaver做网页怎么实现一键复制页面中的文字

小程序 - 实现一键复制功能

关于一键复制HTML代码的功能

js一键复制功能几乎兼容所有浏览器