Vue实现复制粘贴功能

news/2024/7/10 1:11:02 标签: Vue

目录

一、需求说明

二、代码实现

1、安装 vue-clipboard2 依赖

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

3、案例

三、项目所用

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

四、功能升华


本文主要介绍的是 CV复制粘贴文本文字 功能的实现 ,

文章末尾🈶️ CV复制粘贴 图片 后并 上传 的功能的文章推荐。

一、需求说明

在项目中 点击按钮 复制 某行文本是很常见的 应用场景,

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 文件中全局引入插件

示例代码如下:

import Vue from 'vue'
import VueClipBoard from 'vue-clipboard2'

Vue.use(VueClipBoard)

new Vue({
  render: h => h(App)
}).$mount('#app')

3、案例

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

方法一 :

使用 vue-clipboard2 提供的 指令

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

<template>
  <div class="yeluosen">
    <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>
  </div>
</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>
  <div>
    <el-button
      type="success"
      size="small"
      style="margin-left: 10px"
      @click="onCopy"
      >复制</el-button
    >
  </div>
</template>

<script>
export default {
  data() {
    return {
      text: "这是一段复制的文本",
    };
  },
  methods: {
    onCopy() {
      this.$copyText(this.pathText).then(
	      e=>{
	        console.log('复制成功:', e);
	      },
	      e=>{
	        console.log('复制失败:', e);
	      }
      )
    }
  }
};
</script>

三、项目所用

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

<template>
  <div>
    <el-input ref="addressInput" v-model="address" :readonly="true">
      <template slot="prepend"> 反馈地址 </template>
    </el-input>
    <el-button @click="copyLink(address)">复制链接</el-button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      address: "https://www.baidu.com/", // 地址信息
    };
  },
  methods: {
    // 判断是否是 IE 浏览器
    isIE() {
      if (window.ActiveXObject || "ActiveXObject" in window) {
        return true;
      } else {
        return false;
      }
    },
    // 拷贝地址
    copyLink(url) {
      if (this.isIE()) {
        this.$copyText(url);
        this.$refs.addressInput.select(); // 实现选中效果
        this.$message.success("复制成功!");
      } else {
        this.$copyText(url)
          .then((res) => {
            this.$refs.addressInput.select(); // 实现选中效果
            this.$message.success("复制成功!");
          })
          .catch((err) => {
            this.$message.error("该浏览器不支持自动复制, 请手动复制");
          });
      }
    },
  },
};
</script>

<style lang="scss" scoped></style>

四、功能升华

进阶升华部分 :

当你 不光想要 复制粘贴 文本文字 , 还想要 复制粘贴 图片 后 实现 上传 功能 时 :

推荐查询文章 :

1、前端js常用剪贴板(复制粘贴)操作和应用,以及navigator.clipboard新粘贴板API使用

复制粘贴图片推荐参考文章1

2、js在可编辑div中实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)

复制粘贴图片推荐参考文章2

js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)_javascript技巧_脚本之家


http://www.niftyadmin.cn/n/1498064.html

相关文章

python 容器类型_Python基础知识(四)—容器类型通用操作

通用操作 1.数学运算符 &#xff1a;用于拼接两个容器 &#xff1a;用原容器与右侧容器拼接,并重新绑定变量 *&#xff1a;重复生成容器元素 *&#xff1a;用原容器生成重复元素, 并重新绑定变量 < < > > !&#xff1a;依次比较两个容器中元素,一但不同则返回比较…

2020上半年的sequential recommendation论文整理01——概述

由于老师让我整理今年的序列推荐论文&#xff0c;然后我就下载了这么多&#xff0c;包含KDD2020 SIGIR2020 WWW2020还有一些去年的但是没看的。一共是23篇&#xff0c;如下图所示&#xff1a; 这么多论文我准备花时间细看一下&#xff0c;然后写写总结之类的内容。 首先&…

HTML标签的width属性对数字和字母不生效

目录 文本自动换行样式 word-break: break-all 强制换行 word-break: break-all 怎么用 &#xff1f; white-space 属性的 normal 值和 nowrap 值的区别 HTML 标签 的 width 属性设置为 200px &#xff0c;但对 数字 和 字母 无效 &#xff1f;对中文有效 &#xff1b; 数字…

进行数据离散化的原因_数据处理 | pandas入门专题——离散化与one-hot

今天是pandas数据处理专题第7篇文章&#xff0c;可以点击上方专辑查看往期文章。在上一篇文章当中我们介绍了对dataframe进行排序以及计算排名的一些方法&#xff0c;在今天的文章当中我们来了解一下dataframe两个非常重要的功能——离散化和one-hot。离散化离散对应的反面是连…

JavaScript06——作用域、作用域链、预解析

1 - 作用域 1.1 作用域概述 1 2 3 通常来说&#xff0c;一段程序代码中所用到的名字并不总是有效和可用的&#xff0c;而限定这个名字的可用性的代码范围就是这个名字 的作用域。作用域的使用提高了程序逻辑的局部性&#xff0c;增强了程序的可靠性&#xff0c;减少了名字冲突…

教你如何用纯CSS代码实现垂直居中

目录 方法1&#xff1a;设定行高 ( line-height ) 方法2&#xff1a;绝对定位 方法3&#xff1a;利用 transform 方法4&#xff1a;使用表格或假装表格 方法5&#xff1a;使用 Flexbox 十种水平垂直居中方案 &#xff1a; 在编辑一个页面时&#xff0c;通常用到 水平居中…

17秋 软件工程 结对项目 第一次作业(队友副本)

17秋 软件工程 结对项目 第一次作业 成员 陈翔&#xff0c;031502209&#xff1b;李鸣&#xff0c;031502316。客户需求 0.背景 开学初加入学生会部门的迫切需求——选择部门和课余时间冲突之烦恼 选择部门的现状&#xff1a; 各个部门在开学初占据学校青春广场有利位置&#x…

用python实现祝福弹窗_Python实现爆火抖音的弹窗表白软件

Python GUI实现爆火抖音的弹窗表白最近抖音爆火的窗口表白 心中的女孩如果收到了&#xff0c;肯定会看着满屏幕的窗口感动不止&#xff0c;对你倾心 本文是正常版本的源码&#xff0c;BT版本的源码链接待审核 源码 1.正常版本点击喜欢或者不喜欢都会关闭对话框2.BT(变态)版本对…