首先现在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(\'复制失败,请手动复制\')
})
}
以上是笔者自己在实际中遇到的问题及解决办法并不适用所有,仅供参考,如有不对的地方还请多多之指正,共同学习进步
继续阅读与本文标签相同的文章
-
Spring Cloud Alibaba实战(一) - 概述
2026-05-18栏目: 教程
-
php系列----->通过PHP数组实现队列
2026-05-18栏目: 教程
-
MySQL 数据库铁律
2026-05-18栏目: 教程
-
Java 13 明天发布,最新最全新特性解读
2026-05-18栏目: 教程
-
如何使用phpMyAdmin导出Joomla数据库
2026-05-18栏目: 教程
