在vue使用clipboard.js进行一键复制文本的实现示例


Posted in Javascript onJanuary 15, 2019

需求

最近在做商城项目,有个需求是需要点击复制订单号的,然后就觉得可以使用原生的复制方法和使用第三方库。

浏览器原生方法

这种方式兼容性不是太好,还要看浏览器是否支持,容易采坑。

//在IE中可以用window.clipboardData.setData('text','内容')实现。
//在IE中clipboardData是window的属性,而其他浏览器则是相应的event对象的属性,这实际上是一种安全措施,防止未经授权的访问,为了兼容其他浏览器,所以我们不能通过clipboardData来实现这种操作。
//具体做法:
//1.创建一个隐藏的input框
//2.点击的时候,将要复制的内容放进input框中
//3.选择文本内容input.select()
//4.这里只能用input或者textarea才能选择文本。
//5.执行浏览器的复制命令document.execCommand("copy")。
 function copyText() {
  var text = document.getElementById("text").innerText; // 获取要复制的内容也可以传进来
  var input = document.getElementById("input"); // 获取隐藏input的dom
  input.value = text; // 修改文本框的内容
  input.select(); // 选中文本
  document.execCommand("copy"); // 执行浏览器复制命令
  alert("复制成功");
 }

//在事件中可以通过e 对内容进行修饰
document.body.oncopy = e => {
  // 监听全局复制 做点什么
}
 // 还有这种写法:
document.addEventListener("copy", e => {
 // 监听全局复制 做点什么
});

使用 clipboard.js

我们要先安装

npm install clipboard --save

在 mian.js 中引入,当然我们也可以在用到的 .vue 中引入,因为我不止一个地方用到了复制,所以直接在 main.js 里面引入了。

import clipboard from 'clipboard';
//注册到vue原型上
Vue.prototype.clipboard = clipboard;

在需要的地方使用

//dom
···
<div class="sn Lfll Lmr20">订单编号:
  <span data-clipboard-action="copy" class="cobyOrderSn" :data-clipboard-text="orderData.orderSn" @click="copyLink">{{orderData.orderSn}}</span>
 </div>
···
//js
···
 copyLink() {
   let _this = this;
   let clipboard = new this.clipboard(".cobyOrderSn");
   clipboard.on('success', function () {
    _this.$toast("复制成功")
   });
   clipboard.on('error', function () {
    _this.$toast("复制失败")
   });
 }
···

当然 clipboard.js 的功能可不止这么简单,我们还可使用它进行剪切,还可以通过它复制其他元素的值等,具体的使用可查看官方文档: clipboard.js ;

小结

关于浏览器一键复制,推荐使用 clipboard.js 来做,因为现在原生方法兼容性并不是很好,而且 clipboard.js 文件并不大,但是却可以帮我们做很多事情,减轻很多调试和避免采坑。以上只是记录一下自己遇到的问题,如有错误,还请指正,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
node.js中的fs.ftruncate方法使用说明
Dec 15 Javascript
js显示当前日期时间和星期几
Oct 22 Javascript
浏览器复制插件zeroclipboard使用指南
Mar 26 Javascript
JS常用算法实现代码
Nov 14 Javascript
JS实现复制功能
Mar 01 Javascript
Vue报错:Uncaught TypeError: Cannot assign to read only property’exports‘ of object’#‘的解决方法
Jun 17 Javascript
JS中的两种数据类型及实现引用类型的深拷贝的方法
Aug 12 Javascript
layui表格数据重载
Jul 27 Javascript
一篇文章带你浅入webpack的DLL优化打包
Feb 20 Javascript
Vue组件化开发之通用型弹出框的实现
Feb 28 Javascript
详解Vue3 Composition API中的提取和重用逻辑
Apr 29 Javascript
详解webpack的clean-webpack-plugin插件报错
Oct 16 Javascript
2019 年编写现代 JavaScript 代码的5个小技巧(小结)
Jan 15 #Javascript
mock.js实现模拟生成假数据功能示例
Jan 15 #Javascript
详解webpack引入第三方库的方式以及注意事项
Jan 15 #Javascript
JS高阶函数原理与用法实例分析
Jan 15 #Javascript
JS立即执行函数功能与用法分析
Jan 15 #Javascript
vue-cli 目录结构详细讲解总结
Jan 15 #Javascript
webpack file-loader和url-loader的区别
Jan 15 #Javascript
You might like
网友原创的PHP模板类代码
2008/09/07 PHP
PHP为表单获取的URL 地址预设 http 字符串函数代码
2010/05/26 PHP
PHP开发微信支付的代码分享
2014/05/25 PHP
基于win2003虚拟机中apache服务器的访问
2017/08/01 PHP
PHP asXML()函数讲解
2019/02/03 PHP
laravel 解决Validator使用中出现的问题
2019/10/25 PHP
基于jQuery的计算文本框字数的代码
2012/06/06 Javascript
js+css实现tab菜单切换效果的方法
2015/01/20 Javascript
省市联动效果的简单实现代码(推荐)
2016/06/06 Javascript
详解使用JS如何制作简单的ASCII图与单极图
2017/03/31 Javascript
浅谈js使用in和hasOwnProperty获取对象属性的区别
2017/04/27 Javascript
vue+vux实现移动端文件上传样式
2017/07/28 Javascript
解决jquery appaend元素中id绑定事件失效的问题
2017/09/12 jQuery
Angular4的输入属性与输出属性实例详解
2017/11/29 Javascript
vue实现某元素吸顶或固定位置显示(监听滚动事件)
2017/12/13 Javascript
jQuery实现仿京东防抖动菜单效果示例
2018/07/06 jQuery
利用Vconsole和Fillder进行移动端抓包调试方法
2019/03/05 Javascript
深入浅析Vue中mixin和extend的区别和使用场景
2019/08/01 Javascript
vue 全局环境切换问题
2019/10/27 Javascript
vue-cli3项目升级到vue-cli4 的方法总结
2020/03/19 Javascript
VUE项目axios请求头更改Content-Type操作
2020/07/24 Javascript
vue实现点击出现操作弹出框的示例
2020/11/05 Javascript
[01:10:58]Spirit vs NB Supermajor小组赛 A组败者组决赛 BO3 第二场 6.2
2018/06/03 DOTA
Python学习笔记整理3之输入输出、python eval函数
2015/12/14 Python
详解python如何调用C/C++底层库与互相传值
2016/08/10 Python
为什么入门大数据选择Python而不是Java?
2018/03/07 Python
Python入门必须知道的11个知识点
2018/03/21 Python
Python通过正则库爬取淘宝商品信息代码实例
2020/03/02 Python
解析浏览器的一些“滚动”行为鉴赏
2019/09/16 HTML / CSS
英国鹦鹉店:Parrot Essentials
2018/12/03 全球购物
美国按摩椅批发网站:Titan Chair
2018/12/27 全球购物
外贸英语专业求职信范文
2013/12/25 职场文书
观看《永远的雷锋》心得体会
2014/03/12 职场文书
活动总结的格式
2014/05/07 职场文书
机关干部四风问题自我剖析及整改措施
2014/10/26 职场文书
Golang实现可重入锁的示例代码
2022/05/25 Golang