您现在的位置是:首页 > 文章详情

Vue中结合clipboard实现复制功能

日期:2018-10-29点击:499

首先现在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('复制失败,请手动复制')//866109386 })// 面向1-3年前端人员,帮助突技术瓶颈,提升思维能力。 } 

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

原文链接:https://my.oschina.net/u/3970421/blog/2254161
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章