前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue使用Clipboard实现复制功能

Vue使用Clipboard实现复制功能

作者头像
Javanx
发布2019-09-04 15:38:55
1.4K0
发布2019-09-04 15:38:55
举报
文章被收录于专栏:web秀

首先现在Vue中引入clipboard

代码语言:javascript
复制
    npm install clipboard --save

在需要使用的组件中import 引入clipboard

代码语言:javascript
复制
    import Clipboard from 'clipboard';

clipboard的实际使用

不论是单按钮复制还是多按钮复制,一定要在页面加载DOM完成后先New出来具有复制功能的按钮,如果在函数内再New那么可能会出现点击复制按钮两次,才复制成功的现象,如下:

代码语言:javascript
复制
 mounted() {
    var copybtn = document.getElementsByClassName('btn')
    this.clipboard = new Clipboard(copybtn);
}
// 并不一定非要在mounted中也可以在其他周期内,只要页面已经加载完DOM即可,如果是动态生成可以使用nextTick中New。

绑定复制内容的方式有以下几种:

代码语言:javascript
复制
<!--第一种直接绑定在按钮上-->
<button class="marleft10 btn" style="float: right;border: none;" :data-clipboard-text="2" @click="copy()">复制</button>

<!--第二种单个复制按钮动态获取需要复制的内容-->
<input type="text" v-model="copyContent"  id="copy_text" style="opacity: 0">
<button ref="copy"  data-clipboard-action="copy" data-clipboard-target="#copy_text" @click="copy">复制</button>

<!--第三种可以在New Clipboard时设定要复制的内容-->
new Clipboard('copyBtn',function(){
    return <!--要复制的内容-->
})

copy(){
    let _this = this
    <!--如果在内部new会出现点击两次在复制成功的现象所以还请各位多多注意-->
    clipboard.on('success', function () {
        Toast('复制成功')
        _this.destroy() <!--销毁缓存,然后在重新new这样不会出现点击复制上出现之前复制的内容的情况-->
        _this.clipboard = new Clipboard(copyBtn);
    })
    clipboard.on('error', function () { 
        Toast('复制失败,请手动复制')
      })
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年11月6日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档