当前位置: 移动技术网 > IT编程>开发语言>JavaScript > Vue中结合clipboard实现复制功能

Vue中结合clipboard实现复制功能

2018年09月06日  | 移动技术网IT编程  | 我要评论
首先现在vue中引入clipboard
npm install clipboard --save
在需要使用的组件中import 引入clipboard
import clipboard from 'clipboard';
clipboard的实际使用

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

 mounted() {
    var copybtn = document.getelementsbyclassname('btn')
    this.clipboard = new clipboard(copybtn);
    }
<!--并不一定非要在mounted中也可以在其他周期内,
    只要页面已经加载完dom即可,如果是动态生成可以使用nexttick中new。-->

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

<!--第一种直接绑定在按钮上-->
 <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('复制失败,请手动复制')
      })
    }

以上是笔者自己在实际中遇到的问题及解决办法并不适用所有,仅供参考,如有不对的地方还请多多之指正,共同学习进步

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网