怎么在Vue中使用clipboard实现一个复制功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
首先现在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" :data-clipboard-text="2" @click="copy()">复制 </button> <!--第二种单个复制按钮动态获取需要复制的内容--> <input type="text" v-model="copyContent" id="copy_text" > <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('复制失败,请手动复制') }) }
关于怎么在Vue中使用clipboard实现一个复制功能问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。