使用Javascript实现复制粘贴功能的示例代码

 更新时间:2023年09月21日 09:51:53   作者:优秀稳妥的Zn  
本篇文章记录如何通过js代码实现复制内容到剪切板,之后可以粘贴到需要的地方的功能,文中通过代码示例介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

背景

本篇文章记录如何通过js代码实现复制内容到剪切板,之后可以粘贴到需要的地方的功能。

分为两个部分内容:

前两个部分使用execCommand方法,该方法现在被弃用(ps:虽然也还可以用就行了), 且对于单行内容的复制需要结合input标签实现,多行内容的复制需要结合textarea标签实现。

第三个部分,则是现在使用Clipboard API来实现单行或多行内容的复制。(推荐方法)

1、execCommand方法

该方法是在document对象下的方法,现已被弃用,但在这里考虑到以前已经使用过这样的方法实现复制功能了,也写在这里,现在仍然可用。

单行复制

通过input标签将需要复制的内容传递给value属性,之后通过document对象下execCommand方法执行复制功能即可。

具体实现如下:

handleCopy() {
  let copy_text = '需要复制的内容';//拿到想要复制的值
  let input_dom = document.createElement('input');//创建input元素
  input_dom.value = copy_text;//添加需要复制的内容到value属性
  document.body.appendChild(input_dom);//向页面底部追加输入框
  input_dom.select();//选择input元素
  document.execCommand("Copy");//执行复制命令
  alert("复制成功!");//弹出提示信息,不同组件可能存在写法不同
  //复制之后再删除元素,否则无法成功赋值
  input_dom.remove();//删除动态创建的节点
},

上面的方法在页面需要触发复制功能的时候添加到对应鼠标事件即可。

多行复制

通过textarea标签将需要复制的内容传递给value属性,并在需要换行的内容后面加入换行符\r\n,之后通过document对象下execCommand方法执行复制功能即可。

具体实现如下:

handleCopy() {
  let copy_text = '第一行需要复制的内容\r\n第二行需要复制的内容';//拿到想要复制的值
  let textarea_dom = document.createElement('textarea');//创建textarea元素
  document.body.appendChild(textarea_dom);//向页面底部追加输入框
  textarea_dom.value = copy_text; //添加需要复制的内容到value属性
  textarea_dom.select();//选择input元素
  document.execCommand("Copy");//执行复制命令
  alert("复制成功!");//弹出提示信息,不同组件可能存在写法不同
  //复制之后再删除元素,否则无法成功赋值
  document.body.removeChild(textarea_dom); //删除动态创建的节点
}

上面的方法在页面需要触发复制功能的时候添加到对应鼠标事件即可。

2、Clipboard API(推荐)

Clipboard API中的 navigator.clipboard.writeText 方法可以更加简单的实现单行和多行的内容复制,而且该方法会返回一个Promise对象,可以帮助我们简单处理复制成功或复制失败后需要执行的内容。

具体实现如下:

handleCopy() {
  let copy_text = '第一行需要复制的内容\r\n第二行需要复制的内容';//拿到想要复制的值
  // 使用Clipboard API复制文本到剪贴板中
  navigator.clipboard.writeText(copy_text).then(() => {
    alert("复制成功!")
  }).catch((err)=>{
    alert("复制失败!")
  })
}

上面的方法在页面需要触发复制功能的时候添加到对应鼠标事件即可,且在复制内容中,直接支持换行符的实现。

注意:

上面的navigator.clipboard.writeText方法只有在游览器的navigator对象下才会存在clipboard对象;如果你是在vue,react等前端框架中像上面的方法调用clipboard对象,是不存在的。

因为在这类前端框架中编写js的环境下的navigator对象并没有提供clipboard对象,而且clipboard对象并不是navigator对象的标准属性或方法。

因此,在这类框架中需要使用Clipboard API需要通过第三方依赖的方法去实现。

下面以常见的vue框架中使用Clipboard API为例:

1、首先按照第三方Clipboard依赖

npm install clipboard --save

2、在页面文件中引入或在main.js全局引入

import Clipboard from 'clipboard'

3、在需要实现复制功能的方法中,写入实现

<template>
	<div>
    <div class="copy_dom" @click="handleCopy"></div>
  </div>
</template>
<script>
import Clipboard from 'clipboard';
export default {
  data: {
    clipboard: null
  }
  methods: {
  	handleCopy() {
      // 传递事件绑定的元素class名和需要复制的内容text,创建Clipboard实例 
	  this.clipboard = new Clipboard('.copy_dom', {
        text: () => {
          return '第一行需要复制的内容\r\n第二行需要复制的内容'
        }
      });
      // 复制成功后的回调函数
      this.clipboard.on('success', () => {
        // 释放内存,非常重要,不然会重复触发回调函数
		this.clipboard.destroy();
        console.log('复制成功!');
      })
     	// 复制失败后的回调函数
      this.clipboard.on('error', function(e) {
        console.log('复制失败!');
      })
		}
  },
  //beforeDestroy() {
  //  this.clipboard.destroy(); //组件页面销毁时,需要手动清理clipboard,释放内存
  //}
}
</script>

上面的代码中,clipboard实例在复制成功后,建议在success的回调函数中执行实例销毁的destroy方法;也可以在页面组件关闭后的beforeDestroy生命周期执行销毁方法。

以上就是使用Javascript实现复制粘贴功能的示例代码的详细内容,更多关于Javascript复制粘贴功能的资料请关注脚本之家其它相关文章!

相关文章

  • preact组件案例的使用详解

    preact组件案例的使用详解

    SelectValue是一个Preact组件,用于创建一个下拉选择框,它接收props如value、setfn、options和disabled,用于更新父组件中的值、处理下拉选择框的值改变事件、显示选项和禁用或启用下拉选择框,本文介绍preact组件案例的使用详解,感兴趣的朋友一起看看吧
    2025-03-03
  • JavaScript时间对象之常用方法的设置实例

    JavaScript时间对象之常用方法的设置实例

    这篇文章主要为大家介绍了JavaScript时间对象常用方法的设置实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • JavaScript防止全局变量污染的方法总结

    JavaScript防止全局变量污染的方法总结

    这篇文章主要介绍了JavaScript防止全局变量污染的方法,结合实例形式较为详细的总结分析了JavaScript防止全局变量污染的常用操作技巧与注意事项,需要的朋友可以参考下
    2018-08-08
  • JavaScript hasOwnProperty() 函数实例详解

    JavaScript hasOwnProperty() 函数实例详解

    hasOwnProperty()函数用于指示一个对象自身(不包括原型链)是否具有指定名称的属性。下面通过本文给大家分享JavaScript hasOwnProperty() 函数实例讲解,感兴趣的朋友一起看看吧
    2017-08-08
  • H5实现仿flash效果的实现代码

    H5实现仿flash效果的实现代码

    这篇文章主要介绍了H5实现仿flash效果的实现代码的相关资料,希望通过本文能帮助到大家,实现这样的功能,需要的朋友可以参考下
    2017-09-09
  • js生成动态表格并为每个单元格添加单击事件的方法

    js生成动态表格并为每个单元格添加单击事件的方法

    这篇文章主要介绍了使用javascript生成动态表格并为每个单元格添加单击事件,需要的朋友可以参考下
    2014-04-04
  • JavaScript事件对象event用法分析

    JavaScript事件对象event用法分析

    这篇文章主要介绍了JavaScript事件对象event用法,结合实例形式分析了事件对象event中常用的属性、方法、相关操作技巧与注意事项,需要的朋友可以参考下
    2018-07-07
  • 12个div逐个显示效果

    12个div逐个显示效果

    12个div逐个显示效果...
    2006-10-10
  • innerHTML,outerHTML,innerTEXT三者之间的区别

    innerHTML,outerHTML,innerTEXT三者之间的区别

    innerHTML,outerHTML,innerTEXT三者之间的区别...
    2007-01-01
  • JS的replace方法详细介绍

    JS的replace方法详细介绍

    replace() 方法的参数 replacement 可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用
    2012-11-11

最新评论