vue中实现文本复制功能(vue2、vue3均可使用)

方案一:vue中使用clipboard实现文本复制功能(推荐)

1、安装clipboard.js依赖

地址:https://github.com/zenorocha/clipboard.js

yarn add clipboard  或 npm install clipboard --save

2、封装一个文本复制的组件

先在组件文件夹下,如utils目录下新建 clipboard.js 文件

写入以下代码:
import Clipboard from 'clipboard';

function clipboardSuccess() {
    console.log("复制成功")
    //你可以在这里设置你的提示
}
function clipboardError() {
    console.log("复制失败")
}

export default function handleCopy(text, event, onSuccess, onError) {
    event = event || {};
    const clipboard = new Clipboard(event.target, {
        text: () => text,
    });
    clipboard.on('success', () => {
        onSuccess ? onSuccess() : clipboardSuccess();
        clipboard.off('error');
        clipboard.off('success');
        clipboard.destroy();
    });
    clipboard.on('error', () => {
        onError ? onError() : clipboardError();
        clipboard.off('error');
        clipboard.off('success');
        clipboard.destroy();
    });
    clipboard.onClick(event);
}

3、引用及使用组件

<div @click="copyValue('嘻嘻', $event)">点我</div>


import handleCopy from '@/utils/clipboard'

methods:{
    copyValue(text, e){
        let value=text  //这里设置你要复制的文本信息,可以是text,也可以从e中获取,也可以自定义
        handleCopy(value, e, ()=>{
            console.log("这是复制成功回调函数")
            alert("复制成功!")
        },()=>{
            console.log("这是复制失败回调函数")
        })
    }
}

方案二:vue中用clipboard2实现一键复制功能(不兼容vue3)

1、安装插件

yarn add vue-clipboard2

2、在main.js中配置

import VueClipboard from 'vue-clipboard2'
Vue.use(VueClipboard)

3、使用

<a-button v-clipboard:copy="url" v-clipboard:success="copySuc" v-clipboard:error="copyFail">复制链接</a-button>



copySuc(){
    this.$message.success("复制成功")
},

copyFail(){
    this.$message.success("复制失败")
}

4、若不成功,重启项目

posted @ 2021-07-27 17:11  huihuihero  阅读(1761)  评论(0编辑  收藏  举报