欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > vue中el-table单元格复制功能

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

2025/10/25 10:05:09 来源:https://blog.csdn.net/qq_24441205/article/details/140329697  浏览:    关键词: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中写如方法即可

  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,此文件中方法为

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文件

  import { commonMethodsMixin } from '@/utils/columnCopy';

并在export default中使用 mixins: [commonMethodsMixin],如下图
在这里插入图片描述
三、 单击copy图标复制对应的内容到剪切板

  1. 添加copy的小图标
<span v-else><i class="el-icon-document-copy" @click="clickCopy(msg)" />{{ msg }}
</span>
  1. 在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.踩坑
添加了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' })
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词