JavaScript实现一键复制文本功能的示例代码

 更新时间:2023年03月21日 15:08:42   作者:蓝瑟  
这篇文章主要为大家介绍两种javascript实现文本复制(将文本写入剪贴板)的方法,文中的示例代码讲解详细,大家可以根据需求特点选用

最近小编做了一键复制文本的需求(功能如下图所示)。本文简单介绍两种javascript实现文本复制(将文本写入剪贴板)的方法——navigator.clipboarddocument.execCommand(),大家可以根据需求特点选用。

一、navigator.clipboard 对象

1. navigator.clipboard 方法汇总

方法用途
Clipboard.readText()复制剪贴板里的文本数据
Clipboard.read()复制剪贴板里的文本数据/二进制数据
Clipboard.writeText()将文本内容写入剪贴板
Clipboard.write()将文本数据/二进制数据写入剪贴板

2. 代码示例

方法 1: Clipboard.writeText(), 用于将文本内容写入剪贴板;

    document.body.addEventListener("click", async (e) => {
      await navigator.clipboard.writeText("Yo");
    });

方法 2: Clipboard.write(), 用于将文本数据/二进制数据写入剪贴板

Clipboard.write()不仅在剪贴板可写入普通text,还可以写入图片数据(Chrome浏览器仅支持png格式)。

 async function copy() {
   const image = await fetch("kitten.png");
   const text = new Blob(["Cute sleeping kitten"], { type: "text/plain" });
   const item = new ClipboardItem({
     "text/plain": text,
     "image/png": image,
   });
   await navigator.clipboard.write([item]);
 }

3. 优缺点

① 优点

所有操作都是异步的,返回 Promise 对象,不会造成页面卡顿;

无需提前选中内容,可以将任意内容(比如图片)放入剪贴板;

② 缺点: 允许脚本任意读取会产生安全风险,安全限制较多。

Chrome 浏览器规定,只有 HTTPS 协议的页面才能使用这个 API;

调用时需要明确获得用户的许可。

二、document.execCommand() 方法

1. document.execCommand() 方法汇总

方法用途
document.execCommand('copy')复制
document.execCommand('cut')剪切
document.execCommand('paste')粘贴

2. 代码示例

document.execCommand('copy'),用于将已选中的文本内容写入剪贴板。

结合 window.getSelection()方法实现一键复制功能:

    const TestCopyBox = () => {
    const onClick = async () => {
    const divElement = document.getElementById("select-div");
    if (window.getSelection) {
    const selection = window.getSelection();
    const range = document.createRange();
    range.selectNodeContents(divElement);
    selection.removeAllRanges();
    selection.addRange(range);
    }
    document.execCommand("copy");
    };
    return <div>
     <button onClick={onClick}>copy</button>
     <div id="select-div"> <input /> <span>test2: 3</span><span>test3: 94</span></div>
    </div>
    };

3. 优缺点

① 优点

使用方便;

各种浏览器都支持;

② 缺点

只能将选中的内容复制到剪贴板;

同步操作,如果复制/粘贴大量数据,页面会出现卡顿。

到此这篇关于JavaScript实现一键复制文本功能的示例代码的文章就介绍到这了,更多相关JavaScript一键复制文本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信小程序开发常用功能汇总

    微信小程序开发常用功能汇总

    这篇文章主要介绍了微信小程序开发常用功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • viewer.js实现图片预览功能

    viewer.js实现图片预览功能

    这篇文章主要为大家详细介绍了viewer.js实现图片预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • 微信小程序实现简单搜索框

    微信小程序实现简单搜索框

    这篇文章主要为大家详细介绍了微信小程序实现简单搜索框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-09-09
  • JS中Location使用详解

    JS中Location使用详解

    javascript中 location用于获取或设置窗体的URL,并且可以用于解析URL,是BOM中最重要的对象之一,下面我们就来详细探讨下Location对象的使用。
    2015-05-05
  • 网页广告中JS代码的信息监听示例

    网页广告中JS代码的信息监听示例

    在一些网页广告中提供的JS代码可以进行代码注入,然后监视各种元素,下面有个示例,大家可以参考下
    2014-04-04
  • js 实现在2d平面上画8的方法

    js 实现在2d平面上画8的方法

    今天小编就为大家分享一篇js 实现在2d平面上画8的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10
  • js实现运行代码需要刷新的解决方法

    js实现运行代码需要刷新的解决方法

    js实现运行代码需要刷新的解决方法...
    2007-08-08
  • 如何为你的JavaScript代码日志着色详解

    如何为你的JavaScript代码日志着色详解

    这篇文章主要给大家介绍了关于如何为你的JavaScript代码日志进行着色的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用JavaScript具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • JS将秒换成时分秒实现代码

    JS将秒换成时分秒实现代码

    将秒换成时分秒的方法有很多,在本文将为大家介绍下,使用js的具体的实现思路,有需要的朋友可以参考下,希望对大家有所帮助
    2013-09-09
  • JavaScript表格常用操作方法汇总

    JavaScript表格常用操作方法汇总

    这篇文章主要介绍了JavaScript表格常用操作方法,实例汇总了javascript中表格操作的创建、添加、删除、遍历等常用操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04

最新评论