【JavaScript】复制文本到剪切板

✨ 专栏介绍

在现代Web开发中,JavaScript已经成为了不可或缺的一部分。它不仅可以为网页增加交互性和动态性,还可以在后端开发中使用Node.js构建高效的服务器端应用程序。作为一种灵活且易学的脚本语言,JavaScript具有广泛的应用场景,并且不断发展演进。在本专栏中,我们将深入学习JavaScript语言的基本语法、DOM操作、事件处理、异步编程以及常见算法和数据结构等内容。此外,我们还将介绍ES6及其后续版本中引入的新特性,如箭头函数、模块化、解构赋值等。通过学习这些内容,你将能够成为一名熟练的JavaScript开发者,并能够应用这些知识来构建出高质量和可维护的Web应用程序。让我们一起开始JavaScript之旅吧!

在这里插入图片描述


一、Clipboard API

Clipboard API是现代浏览器提供的一组JavaScript接口,用于访问和操作用户剪贴板中的内容。它提供了异步读取和写入剪贴板的功能,可以处理多种类型的数据,如文本、图像等。通过使用navigator.clipboard对象,开发者可以调用相关方法来读取和写入剪贴板中的内容。

相关属性方法

属性:

  • clipboardData:表示剪贴板中的数据对象。
  • types:返回剪贴板中数据的类型列表。

方法:

  • readText():异步读取剪贴板中的文本内容。
  • writeText(text):异步将文本内容写入剪贴板。
  • read():异步读取剪贴板中的数据对象。
  • write(data):异步将自定义数据对象写入剪贴板。

示例

const copyText = () => {const text = "Hello, Clipboard API!";navigator.clipboard.writeText(text).then(() => {console.log("Text copied to clipboard");}).catch((error) => {console.error("Failed to copy text: ", error);});
}

在这里插入图片描述

二、document.execCommand

document.execCommand()是一个旧的浏览器API,用于执行命令并影响浏览器行为。其中包括一些与剪贴板相关的命令,如复制、粘贴等。通过调用document.execCommand('copy')document.execCommand('paste')等命令,可以实现对剪贴板内容进行读取或写入。

const copyText = () => {const text = "Hello, Clipboard!"const textarea = document.createElement('textarea')textarea.value = texttextarea.style.position = 'absolute'textarea.style.opacity = '0'document.body.appendChild(textarea)textarea.select()document.execCommand('copy')document.body.removeChild(textarea)
};
优点:
  • 使用简单,无需额外引入API。
  • 兼容性好。

image.png

缺点:
  • 功能相对有限,只能处理文本类型的数据。
  • 不支持异步操作。
  • 安全性和用户隐私保护较差。

需要注意的是,document.execCommand()在现代浏览器中已经被废弃,不再推荐使用。而Clipboard API是未来发展的趋势,提供了更好的功能和安全性。因此,在支持Clipboard API的浏览器中,建议使用Clipboard API来进行剪贴板操作。对于不支持Clipboard API的浏览器,可以使用document.execCommand()作为降级方案。

三、useClipboard

  1. 检测浏览器是否支持navigator.clipboard
const isClipboardSupported = () => {return !!navigator.clipboard && typeof navigator.clipboard.writeText === 'function';
};
  1. 创建一个名为fallbackCopyText的函数,用于在不支持Clipboard API的浏览器中实现复制功能:
const fallbackCopyText = (text) => {const textarea = document.createElement('textarea')textarea.value = texttextarea.style.position = 'absolute'textarea.style.opacity = '0'document.body.appendChild(textarea)textarea.select()document.execCommand('copy')textarea.remove()
};
  1. 在自定义hooks中,根据浏览器是否支持Clipboard API来选择使用哪种复制方式:
const useClipboard = () => {const copied = ref(false);const copyText = (text) => {if (isClipboardSupported()) {navigator.clipboard.writeText(text).then(() => {copied.value = true;}).catch((error) => {console.error("Failed to copy text: ", error);});} else {fallbackCopyText(text);copied.value = true;}};return { copied, copyText };
};

通过以上降级方案,我们首先检测浏览器是否支持navigator.clipboard。如果支持,则使用navigator.clipboard.writeText()来复制文本。如果不支持,则调用fallbackCopyText()函数来实现复制功能。

在使用自定义hooks的Vue组件中,无需更改任何代码,因为自定义hooks已经处理了浏览器兼容性问题。无论浏览器是否支持Clipboard API,都可以正常使用复制功能。

降级方案中的fallbackCopyText()函数使用了document.execCommand('copy')来执行复制操作。这是一种旧的方式,在现代浏览器中仍然有效,但并不推荐使用。因此,在支持Clipboard API的浏览器中,尽量优先使用navigator.clipboard.writeText()来实现复制功能。


😶 写在结尾

前端设计模式专栏

在这里插入图片描述

设计模式是软件开发中不可或缺的一部分,它们帮助我们解决了许多常见问题,并提供了一种优雅而可靠的方式来构建应用程序。在本专栏中,我们介绍了所有的前端设计模式,包括观察者模式、单例模式、策略模式等等。通过学习这些设计模式,并将其应用于实际项目中,我们可以提高代码的可维护性、可扩展性和可重用性。希望这个专栏能够帮助你在前端开发中更好地应用设计模式,写出高质量的代码。点击订阅前端设计模式专栏

Vue专栏

在这里插入图片描述

Vue.js是一款流行的JavaScript框架,用于构建用户界面。它采用了MVVM(Model-View-ViewModel)的架构模式,通过数据驱动和组件化的方式,使开发者能够更轻松地构建交互性强、可复用的Web应用程序。在这个专栏中,我们将深入探讨Vue.js的核心概念、组件开发、状态管理、路由和性能优化等方面的知识。我们将学习如何使用Vue.js构建响应式的用户界面,并探索其强大的生态系统,如Vue Router和Vuex、Pinia。通过学习这些内容,你将能够成为一名熟练的Vue.js开发者,并能够应用这些知识来构建复杂而高效的Web应用程序。点击订阅Vue专栏

JavaScript(ES6)专栏

在这里插入图片描述

JavaScript是一种广泛应用于网页开发和后端开发的脚本语言。它具有动态性、灵活性和易学性的特点,是构建现代Web应用程序的重要工具之一。在这个专栏中,我们将深入探讨JavaScript语言的基本语法、DOM操作、事件处理、异步编程以及常见算法和数据结构等内容。此外,我们还将介绍ES6(ECMAScript 2015)及其后续版本中引入的新特性,如箭头函数、模块化、解构赋值等。通过学习这些内容,你将能够成为一名熟练的JavaScript开发者,并能够应用这些知识来构建出高质量和可维护的Web应用程序。点击订阅JavaScript(ES6)专栏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/578591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Failed to configure a DataSource: ‘url‘ attribute is not specified xxx 的另一种解决方法

报错信息: *************************** APPLICATION FAILED TO START ***************************Description:Failed to configure a DataSource: url attribute is not specified and no embedded datasource could be configured.Reason: Failed to determine …

tvbox最新接口配置

TVBox是在Github的开源项目,本身是一个空壳软件,可免费使用及再开发。安装后需要配置接口才能正常使用。 TVBox,也被称为网络电视盒子,是一种可以连接到电视的设备,使电视具有智能电视的功能。TVBox的主要功能是通过网…

免费高清无水印视频素材在哪里下?

剪辑是一门创意工作,但很多初学者常常感到困惑,原因并不是因为他们不懂剪辑,而是因为他们不知道从哪里找到合适的素材。今天,我们将为大家盘点一些超全的剪辑素材资源,包括视频素材、音乐素材和图片素材等,…

WAVE SUMMIT迎来第十届,文心一言将有最新披露!

10句话2分钟,挑战成功说服宿管阿姨开门,这个人群中的“显眼包”是一个接入文心大模型4.0游戏里的NPC,妥妥 “工具人”实锤~ 尝试用AI一键自动识别好坏咖啡豆,看一眼便知好坏,真正“颜值即正义”&#xff0…

初识Nginx默认配置文件

说起配置Nginx确实是一件让人头疼的事,开始时对Nginx配置不熟悉,为了满足需求在网上查找了很多相关配置的博客,也是天花乱坠不知道谁对谁错。就不停反复尝试最终在不懈的努力下中终于成功了。那时就觉得是时候好好整理一下Nginx的相关配置了。…

【Echarts】前端echarts 常用总结

文章目录 一、vue2 项目如何使用echarts二、Echarts设置柱状图y轴最⼩刻度为1三、echarts报错 echarts is not defined四、Echarts 柱形图实现从右向左滚动 一、vue2 项目如何使用echarts 在vue2项目中使用echarts 二、Echarts设置柱状图y轴最⼩刻度为1 在 Vue 中使⽤ Echar…

一个基于多接口的业务自动化测试框架!

这是一个成熟的框架,不是要让别人当小白鼠,它已经先后在两家公司的5条业务线进行了推广应用,用例条数到了几千条以上,并且从2018年开始每天都在CI/CD流程中被调用执行。 已有那么多接口测试框架,为什么重复造轮子&…

注解实现接口鉴权和防刷限制

注解实现接口鉴权和防刷限制 步骤1. 自定义注解2. 自定义Interceptor3. 拦截器注入Springboot4. 使用 项目中需要对开放给第三方接口实现鉴权和防刷限制可以使用自定义注解和Interceptor来实现 步骤 1. 自定义注解 Retention(RetentionPolicy.RUNTIME) Target(ElementType.ME…

Docker 创建容器

1、创建MySQL 拉取镜像:docker pull mysql:5.7创建容器:docker run -d --name mysql57001 -p 3306:3306 -v D:\DockerImage\QhData\MySql57:/var/lib/mysql -e MYSQL_ROOT_PASSWORD123456 mysql:5.7进入容器:docker exec -it mysql57001 bas…

深度学习框架TensorFlo

深度学习框架TensorFlow TensorFlow简介第一个TensorFlow应用TensorFlow APITensorFlow基础概念TensorFlow张量(Tensor)TensorFlow张量维度TensorFlow张量形状(Shape)TensorFlow张量数据类型(Data Type)Te…

北亚服务器数据恢复-服务器断电导致raid5故障的数据恢复案例

服务器数据恢复环境: 服务器有一组由12块硬盘组建的raid5阵列。 服务器故障&分析: 机房供电不稳导致服务器意外断电,工作人员重启服务器后发现服务器无法正常使用。 根据故障情况,北亚企安数据恢复工程师初步判断服务器故障原…

在Windows 10中,设置DNS的入口有三个,包括命令提示符

作为你互联网接入订阅的一部分,互联网服务提供商(ISP)还为本地网络提供必要的设置,包括域名系统(DNS)地址,以便访问你喜爱的网站、在线服务和下载文件。 唯一需要注意的是,ISP的DNS服务器通常不是私用的,比其他服务慢,有时也不可靠。然而,你可以随时使用来自第三方…

termux 配置和系统安装

1、termux 配置 去 termux官网 下载对应的 APK 并安装即可 Termux 是 Android 平台上的一个终端模拟器,它将众多 Linux 上运行的软件和工具近乎完美的移植到了手机端。 换源 由于 Termux 默认使用国外的镜像源,在国内访问国外服务器会很慢或者连接不上…

SQL数据工程师面试题20231226

1、数据库知识: 表一:Stock(商品库存入库表) 商品编号 入库数量 描述 A 300 A B 400 B C 200 C 注: Stock 表的商品编号是唯一主键。 表二: OutStock(商品库存出库表) 商品编号 出库数量 描述 A 100 A B 40 B B 50 B 注: outStock 表同一个商品存在多次出库。 – 创建 Stoc…

MyBatis见解4

10.MyBatis的动态SQL 10.5.trim标签 trim标签可以代替where标签、set标签 mapper //修改public void updateByUser2(User user);<update id"updateByUser2" parameterType"User">update user<!-- 增加SET前缀&#xff0c;忽略&#xff0c;后缀…

vue3学习之路

reactive, ref响应式数据 let num reactive(0)// reactive中是简单数据类型&#xff0c;不会自动响应到页面中&#xff0c;除非有对象类型要响应才会跟着响应到页面 const obj reactive({num: 0,name: malinshu })const add () > {num;obj.num;obj.name obj.name -- }…

WizFi360-EVB-Pico评估版介绍

文章目录 1 概述2 硬件资源2.1 硬件规格2.2 引脚定义2.3 工作条件 3 参考资料3.1 Datasheet3.2 原理图3.3 尺寸图(单位 : mm) 3.4 参考例程 1 概述 WizFi360-EVB-Pico基于树莓派RP2040&#xff0c;并使用WizFi360增加Wi-Fi连接。它与树莓派Pico板引脚兼容&#xff0c;可用于物联…

一个越南程序员的阿里巴巴之旅

译者 蒋辉文&#xff0c;公众号&#xff1a;ali老蒋 文章说明 本文访谈主人公是一个越南程序员&#xff0c;原来在 Lazada 工作。后来&#xff0c;Lazada 被阿里收购&#xff0c;他就来到阿里&#xff0c;在杭州阿里巴巴西溪园区呆过一段时间。现在&#xff0c;他已经跳槽到…

【MySQL】数据库规范化的三大法则 — 一探范式设计原则

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; 数 据 库 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 1. 第一范式&#xff08;1NF&#xff09;&#xff1a; 2. 第二范式&#xff08;2NF&#xff09;&#xff1a; 3. 第三范式…

打字练习软件推荐:Master of Typing 3 中文 for Mac

"Master of Typing 3"是一款针对打字练习和提高打字速度的软件。它提供了一系列有趣和有挑战性的练习&#xff0c;旨在帮助用户提高键盘打字技能和准确性。 以下是"Master of Typing 3"的一些主要特点和功能&#xff1a; 打字练习&#xff1a;软件提供了各…