vue中实现复制内容到剪切板

本文介绍了如何在Element-UI的el-table中实现单元格双击复制内容到剪贴板,并添加单击复制图标功能。遇到的问题是全局`copy`事件干扰,通过`once`参数解决。详细步骤包括添加事件监听和相应方法。

1. element-ui的el-table实现双击复制单元格的内容到剪切板

1. 在el-table中添加双击响应事件

<el-table
      :data="tableData"
      @cell-dblclick="copyText"
      border
    >
    .....
<el-table>

cell-dblclick函数有四个参数,分别是row, column, cell, event;

row:可看到被操作单元格所在行的所有的数据;
cloumn:可以看到被操作单元格的property,根据property可以再row中得到该单元格的值;
cell:可看到该单元格的dom结构;
event:事件触发时的所有参数;

2. 在methods中添加双击绑定的copyText方法

copyText(row, column, cell, event){
  // 双击复制
  let save = function (e){
    e.clipboardData.setData('text/plain',event.target.innerText); 
    e.preventDefault();  //阻止默认行为
  }
  document.addEventListener('copy',save);//添加一个copy事件
  document.execCommand("copy");//执行copy方法
  this.$message({message: '复制成功', type:'success'})//提示
}

2. 单击copy图标复制对应的内容到剪切板

1. 添加copy的小图标

<span v-else>
  <i class="el-icon-document-copy" @click="clickCopy(msg)" />
  {{ msg }}
</span>

2. 在methods中添加单击复制的clickCopy方法

clickCopy(msg) {
  const save = function(e) {
    e.clipboardData.setData('text/plain', msg)
    e.preventDefault() // 阻止默认行为
  }
  document.addEventListener('copy', save) // 添加一个copy事件
  document.execCommand('copy') // 执行copy方法
  this.$message({ message: '复制成功', type: 'success' })
}

3.踩坑

1. 添加了copy事件之后整个页面按ctrl+c复制东西没反应了

猜测是使用document.addEventListener(‘copy’, save)会在整个dom树添加事件,会覆盖dom树原有的事件的发生,所以需要添加once参数使这个事件只生效一次
once 表示 listener 在添加之后最多只调用一次。如果是 true, listener 会在其被调用之后自动移除

clickCopy(msg) {
      const save = function(e) {
        e.clipboardData.setData('text/plain', msg)
        e.preventDefault() // 阻止默认行为
      }
      const once = {
        once: true
      }
      document.addEventListener('copy', save, once) // 添加一个copy事件,当触发时执行一次,执行完删除
      document.execCommand('copy') // 执行copy方法
      this.$message({ message: '复制成功', type: 'success' })
    }

4.eventlistener参考:

https://developer.mozilla.org/zh-CN/docs/Web/API/EventTarget/addEventListener

Vue实现将指定内容复制剪切板有多种方法,以下为你详细介绍: 1. **使用Vue指令**:可自定义指令,使元素支持复制文本到剪贴板。 ```vue <template> <div> <button v-copy="text">复制文本</button> </div> </template> <script> export default { data() { return { text: 'Hello World' } } } </script> <script> // 注册指令 Vue.directive('copy', { bind: function(el, binding) { el.$copy = function() { const textarea = document.createElement('textarea'); textarea.value = binding.value; document.body.appendChild(textarea); textarea.select(); document.execCommand('Copy'); document.body.removeChild(textarea); } el.addEventListener('click', el.$copy); }, unbind: function(el) { el.removeEventListener('click', el.$copy); } }); </script> ``` 这样,在Vue组件的模板中,就可以通过`v-copy`的形式来使用这个指令,将指定的内容复制剪切板中,例如: ```vue <template> <div v-copy="'要复制的文本内容'">点击我复制内容</div> </template> ``` 2. **使用原生Js实现**:此方法是用来对请求后数据处理并复制剪切板的一个基本功能。 ```vue <template> <!-- 模板部分 --> </template> <script> export default { methods: { async copyCookie(uid) { const { data: res } = await this.$http.get(`/lottery/copyCookie/${uid}`); if (res.status!== 200) return this.$message.error(res.msg); this.handleCopyContent(res.data); // 调用方法复制到剪切版 this.$message.success(res.msg); }, handleCopyContent(content) { const input = document.createElement('input'); // 创建input对象 input.value = content; // 设置复制内容 document.body.appendChild(input); // 添加临时实例 input.select(); // 选择实例内容 document.execCommand('Copy'); // 执行复制 document.body.removeChild(input); // 删除临时实例 } } } </script> ``` 3. **使用Vue插件方式**:可以安装`vue-clipboard2`插件实现复制功能。 ```bash npm install --save vue-clipboard2 ``` 在`main.js`引入: ```javascript import VueClipboards from 'vue-clipboard2'; Vue.use(VueClipboards); ``` 使用示例: ```vue <template> <el-button type="text" class="btn" @click="copy(i.phone)">复制号码</el-button> </template> <script> export default { methods: { copy(phone) { this.$copyText(phone).then(() => { this.$message.success('复制成功'); }); } } } </script> ``` 4. **使用`clipboard.js`库**:虽然引用中未详细给出代码,但这也是一种常见的实现方式,你可以通过安装该库并按照其文档进行使用。 ### 相关问题 1.Vue中使用原生Js实现复制剪切板时,`document.execCommand('Copy')`在现代浏览器中是否存在兼容性问题? 2. 使用`vue-clipboard2`插件复制内容失败时,如何进行错误处理? 3. 自定义Vue指令实现复制功能时,如何添加复制成功的提示信息? 4. `clipboard.js`库与其他几种复制方法相比,有哪些优缺点? 5.Vue项目中,同时使用多种复制剪切板的方法会有冲突吗?
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱学习的狮王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值