• 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",

    2、在 main.js 文件中全局引入插件

    示例代码如下:

    1. import Vue from 'vue'
    2. import VueClipBoard from 'vue-clipboard2'
    3. Vue.use(VueClipBoard)
    4. new Vue({
    5. render: h => h(App)
    6. }).$mount('#app')

    3、案例

    在组件中有两种方法可以实现复制功能。

    方法一 :

    使用 vue-clipboard2 提供的 指令

    直接将变量内容复制至剪切板,暂时没有找到处理数据后再复制的方式

    1. <template>
    2. <div class="yeluosen">
    3. <input type="text" v-model="message">
    4. <el-button
    5. icon="el-icon-share"
    6. size="mini"
    7. style="font-size: 16px;padding: 4px 8px;"
    8. title="共享"
    9. v-clipboard:copy="scope.row.url"
    10. v-clipboard:success="onCopy"
    11. v-clipboard:error="onError"
    12. @click="share(scope.row.url)"></el-button>
    13. </div>
    14. </template>

    复制时,通过 v-clipboard: copy 复制输入的内容 :

    1. // 复制成功 or 失败(提示信息!!!)
    2. onCopy: function (e) {
    3. console.log('复制成功!', e)
    4. },
    5. onError: function (e) {
    6. console.log('复制失败!', e)
    7. }

    方法二:
    使用 vue-clipboard2 全局绑定的 $copyText 事件方法

    复制动作使用的是 Vue 响应函数方式,这就为复制前控制数据提供了可能!

    1. // 点击事件
    2. share(val) {
    3. this.handleData(val)
    4. this.$copyText(this.message).then(function (e) {
    5. alert('Copied')
    6. }, function (e) {
    7. alert('Can not copy')
    8. })
    9. },
    10. // 数据处理
    11. handleData(val){
    12. this.message = this.message + ' ' + val
    13. }
    1. <template>
    2. <div>
    3. <el-button
    4. type="success"
    5. size="small"
    6. style="margin-left: 10px"
    7. @click="onCopy"
    8. >复制</el-button
    9. >
    10. </div>
    11. </template>
    12. <script>
    13. export default {
    14. data() {
    15. return {
    16. text: "这是一段复制的文本",
    17. };
    18. },
    19. methods: {
    20. onCopy() {
    21. this.$copyText(this.pathText).then(
    22. e=>{
    23. console.log('复制成功:', e);
    24. },
    25. e=>{
    26. console.log('复制失败:', e);
    27. }
    28. )
    29. }
    30. }
    31. };
    32. </script>

    三、项目所用 :

    实现选中并且复制成功后带有提示信息的效果 :

    1. <template>
    2. <div>
    3. <el-input ref="addressInput" v-model="address" :readonly="true">
    4. <template slot="prepend"> 反馈地址 </template>
    5. </el-input>
    6. <el-button @click="copyLink(address)">复制链接</el-button>
    7. </div>
    8. </template>
    9. <script>
    10. export default {
    11. data() {
    12. return {
    13. address: "https://www.baidu.com/", // 地址信息
    14. };
    15. },
    16. methods: {
    17. // 判断是否是 IE 浏览器
    18. isIE() {
    19. if (window.ActiveXObject || "ActiveXObject" in window) {
    20. return true;
    21. } else {
    22. return false;
    23. }
    24. },
    25. // 拷贝地址
    26. copyLink(url) {
    27. if (this.isIE()) {
    28. this.$copyText(url);
    29. this.$refs.addressInput.select(); // 实现选中效果
    30. this.$message.success("复制成功!");
    31. } else {
    32. this.$copyText(url)
    33. .then((res) => {
    34. this.$refs.addressInput.select(); // 实现选中效果
    35. this.$message.success("复制成功!");
    36. })
    37. .catch((err) => {
    38. this.$message.error("该浏览器不支持自动复制, 请手动复制");
    39. });
    40. }
    41. },
    42. },
    43. };
    44. </script>
    45. <style lang="scss" scoped></style>
  • 相关阅读:
    Linux下C/C++实现进程内存使用分析工具(memstat)
    代码随想录算法训练营day48|打家劫舍 |198.打家劫舍|213.打家劫舍II|337.打家劫舍 III
    C#面:关于集合的几个选择题
    Flask入门学习教程
    《网络安全笔记》第十二章:二进制基础
    Flink - ProcessFunction 使用缓存详解
    C++11多线程
    972信息检索 | 第七章 专类信息的检索
    mysql面试题7:MySQL事务原理是什么?MySQL事务的隔离级别有哪些?
    VirtualBox设置共享文件夹步骤及遇到的问题
  • 原文地址:https://blog.csdn.net/weixin_58099903/article/details/125273657