VUE如何复制内容到粘贴板
- 复制内容到粘贴板
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'})//提示
}
or
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' })
}
- 坑—添加了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' })
}