Vue实现复制粘贴功能
目录一、需求说明
二、代码实现
1、安装 vue-clipboard2 依赖
2、在 main.js 文件中全局引入插件
3、案例
三、项目所用 :
实现选中并且复制成功后带有提示信息的效果 :
一、需求说明
在项目中 点击按钮 复制 某行文本是很常见的 应用场景,
在 Vue 项目中实现 复制功能 需要借助 vue-clipboard2 插件。
二、代码实现
1、安装 vue-clipboard2 依赖
( 出现错误的话,可以试试切换成淘宝镜像源
npm config set registry https://registry.npm.taobao.org )
npm install --save vue-clipboard2 "vue-clipboard2": "^0.3.3",
https://img-blog.csdnimg.cn/8cf09be4fcfc4699b8a783f8e180a9ab.png
2、在 main.js 文件中全局引入插件
示例代码如下:
import Vue from 'vue'
import VueClipBoard from 'vue-clipboard2'
Vue.use(VueClipBoard)
new Vue({
render: h => h(App)
}).$mount('#app') 3、案例
在组件中有两种方法可以实现复制功能。
方法一 :
使用 vue-clipboard2 提供的 指令
直接将变量内容复制至剪切板,暂时没有找到处理数据后再复制的方式
<template>
<input type="text" v-model="message">
<el-button
icon="el-icon-share"
size="mini"
style="font-size: 16px;padding: 4px 8px;"
title="共享"
v-clipboard:copy="scope.row.url"
v-clipboard:success="onCopy"
v-clipboard:error="onError"
@click="share(scope.row.url)"></el-button>
</template> 复制时,通过 v-clipboard: copy 复制输入的内容 :
// 复制成功 or 失败(提示信息!!!)
onCopy: function (e) {
console.log('复制成功!', e)
},
onError: function (e) {
console.log('复制失败!', e)
} 方法二:
使用 vue-clipboard2 全局绑定的 $copyText 事件方法
复制动作使用的是 Vue 响应函数方式,这就为复制前控制数据提供了可能!
// 点击事件
share(val) {
this.handleData(val)
this.$copyText(this.message).then(function (e) {
alert('Copied')
}, function (e) {
alert('Can not copy')
})
},
// 数据处理
handleData(val){
this.message = this.message + ' ' + val
} <template>
<el-button
type="success"
size="small"
style="margin-left: 10px"
@click="onCopy"
>复制</el-button
>
</template> 三、项目所用 :
实现选中并且复制成功后带有提示信息的效果 :
<template>
<input type="text" v-model="message">
<el-button
icon="el-icon-share"
size="mini"
style="font-size: 16px;padding: 4px 8px;"
title="共享"
v-clipboard:copy="scope.row.url"
v-clipboard:success="onCopy"
v-clipboard:error="onError"
@click="share(scope.row.url)"></el-button>
</template> 反馈地址 复制链接
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
页:
[1]