vue中el-table单元格复制功能

一、单页面中使用

1.在el-table上绑定单击事件 @cell-click="copyText" 或双击事件 @cell-dblclick="copyText"

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

row:可看到被其操作单元格所在行的所有的数据;

cloumn:可以看到被其操作单元格的property,根据property可以再row中得到该单元格的值;

cell:可看到该单元格的dom结构;

event:事件触发时的所有参数;

2.在methods中写如方法即可

c 复制代码
  copyText(row, column, cell, event){
      console.log('****column***',column)
      if(column.label!='操作'){
        // 双击复制
        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'})//提示
      }else {
         return
      }
    },

二、封装成组件,使用mixins

Mixins 是一种让多个组件之间共享Vue选项的方式,适合抽取和复用多个组件的相同选项或逻辑。你可以把公共方法封装在一个 mixin 中,然后在需要的组件中引入和使用。

Mixin 示例 (新建columnCopy.js):

1.在el-table上绑定单击事件 @cell-click="copyText" 或双击事件 @cell-dblclick="copyText"

2.新建columnCopy.js,此文件中方法为

c 复制代码
export const commonMethodsMixin = {
  methods: {
    copyText(row, column, cell, event){
      console.log('****column***',column)
      if(column.label!='操作'){
        // 双击复制
        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'})//提示
      }else {
         return
      }

    },
  }
};

3.在使用此方法的组件中引入columnCopy.js文件

c 复制代码
  import { commonMethodsMixin } from '@/utils/columnCopy';

并在export default中使用 mixins: [commonMethodsMixin],如下图

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

  1. 添加copy的小图标
c 复制代码
<span v-else>
  <i class="el-icon-document-copy" @click="clickCopy(msg)" />
  {{ msg }}
</span>
  1. 在methods中添加单击复制的clickCopy方法
c 复制代码
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.踩坑

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

猜测是使用document.addEventListener('copy', save)会在整个dom树添加事件,会覆盖dom树原有的事件的发生,所以需要添加once参数使这个事件只生效一次

once 表示 listener 在添加之后最多只调用一次。如果是 true, listener 会在其被调用之后自动移除

c 复制代码
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' })
}
相关推荐
brief of gali2 分钟前
记录一个奇怪的前端布局现象
前端
计算机毕设指导66 分钟前
基于 SpringBoot 的作业管理系统【附源码】
java·vue.js·spring boot·后端·mysql·spring·intellij-idea
前端拾光者41 分钟前
利用D3.js实现数据可视化的简单示例
开发语言·javascript·信息可视化
Json_181790144801 小时前
电商拍立淘按图搜索API接口系列,文档说明参考
前端·数据库
风尚云网1 小时前
风尚云网前端学习:一个简易前端新手友好的HTML5页面布局与样式设计
前端·css·学习·html·html5·风尚云网
木子02041 小时前
前端VUE项目启动方式
前端·javascript·vue.js
GISer_Jing1 小时前
React核心功能详解(一)
前端·react.js·前端框架
捂月1 小时前
Spring Boot 深度解析:快速构建高效、现代化的 Web 应用程序
前端·spring boot·后端
深度混淆2 小时前
实用功能,觊觎(Edge)浏览器的内置截(长)图功能
前端·edge
Smartdaili China2 小时前
如何在 Microsoft Edge 中设置代理: 快速而简单的方法
前端·爬虫·安全·microsoft·edge·社交·动态住宅代理