百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

前端 JavaScript 复制粘贴的奥义——Clipboard 对象概述

yuyutoo 2024-10-13 00:35 5 浏览 0 评论

前言

作为一名资深搬砖工,你要问我用得最熟练的技能是什么,那我敢肯定且自豪的告诉你:是 Ctrl+C !是 Ctrl+V

不信?你来看看我键盘上的 Ctrl、C 和 V 键,那油光发亮的包浆程度,不盘个三五年是绝对达不到的!

编程界的江湖上曾经流传着一句话:CV da fa 好,CV da fa 妙!主要看疗效,谁用谁知道!(为防河蟹,且用拼音凑合着)

从这句话就可以看出编程界的同仁们对 CV 的追捧和狂热,简直是席卷大街小巷、风靡大江南北!一时之间,不知让多少 IT 英雄们“竞折腰”,即使到了现在,它依然是编程入门的必修技能!

那么,CV 到底有什么魔力,能让人这么着迷,一代又一代的传承不息呢?

今天,让我们一起来揭开前端 JavaScript 开发界 CV 的面纱,一睹真容(套路)!

旧法

世界上最好的语言—— JavaScript,必然是有着访问系统剪切板的功能的,主要依靠 Document.execCommand() 接口实现复制、粘贴、剪切等功能。

  • document.execCommand('copy')
  • document.execCommand('cut')
  • document.execCommand('paste')

复制

const inputEle = document.querySelector('#input');
inputEle.select();
document.execCommand('copy');

首先获取到这个 input 元素,然后选中 input 中的内容,再调用复制接口,将 input 内容复制到剪切板。

注意,复制操作最好放在事件监听函数里面,由用户触发(比如用户点击按钮)。

粘贴

const pasteText = document.querySelector('#output');
pasteText.focus();
document.execCommand('paste');

首先让 input 元素获得焦点,然后调用粘贴接口,将剪切板内容粘贴到 input。

剪切

用法同复制

小结

从上面的示例来看,剪切板 API 用着很简单,但它有以下不足:

  1. 它不够灵活,只能将选中的内容复制到剪贴板,无法向剪贴板任意写入内容。
  2. 它是同步操作,如果复制/粘贴大量数据,页面会出现卡顿。
  3. 有些浏览器还会跳出提示框,要求用户许可,这时在用户做出选择前,页面会失去响应。

进化 ——Clipboard

为了使 JavaScript 更加灵活的操作剪切板,也是为了顺应 JS 发展的历史潮流,Clipboard API 应运而生。它是下一代的剪贴板操作方法,比传统的document.execCommand()方法更强大、更合理。

Clipboard 接口实现了 Clipboard API,如果用户授予了相应的权限,就能提供系统剪贴板的读写访问。在 Web 应用程序中,Clipboard API 可用于实现剪切、复制和粘贴功能。

它的所有操作都是异步的,返回 Promise 对象,不会造成页面卡顿。而且,它可以将任意内容(比如图片)放入剪贴板。

该 API 被设计用来取代使用 document.execCommand() 的剪贴板访问方式。

基本使用

navigator.clipboard 属性返回 Clipboard 对象,所有操作都通过这个对象进行。

(async () => {
    const text = await navigator.clipboard.readText();
    console.log(text);
})();

如果navigator.clipboard属性返回undefined,就说明当前浏览器不支持这个 API。

安全限制

  1. Chrome 浏览器规定,只有 HTTPS 协议的页面才能使用这个 API。不过,开发环境(localhost)允许使用非加密协议。
  2. 调用时需要明确获得用户的许可。权限的具体实现使用了 Permissions API,跟剪贴板相关的有两个权限:clipboard-write(写权限)和clipboard-read(读权限)。“写权限”自动授予脚本,而“读权限”必须用户明确同意给予。也就是说,写入剪贴板,脚本可以自动完成,但是读取剪贴板时,浏览器会弹出一个对话框,询问用户是否同意读取。

脚本读取的总是当前页面的剪贴板。这带来的一个问题是,如果把相关的代码粘贴到开发者工具中直接运行,可能会报错,因为这时的当前页面是开发者工具的窗口,而不是网页页面。

如果用户没有适时使用 Permissions API) 授予相应权限和"clipboard-read""clipboard-write" 权限,调用 Clipboard 对象的方法不会成功。

方法

Clipboard 对象提供了四个方法,用来读写剪贴板。它们都是异步方法,返回 Promise 对象。

  • read() 从剪贴板读取数据(比如图片),返回一个 Promise对象。
  • readText() 从操作系统读取文本,返回一个 Promise对象。
  • write() 写入任意数据至操作系统剪贴板。
  • writeText() 写入文本至操作系统剪贴板。

浏览器兼容性

目前,各个浏览器厂商正在逐步开始支持 Clipboard 对象及其方法,兼容性如下:

总结

对上面所说的做一个总结:

  1. Clipboard 对象的方法,返回一个 Promise 对象
  2. Clipboard 的使用存在一定的安全限制,需要注意。
  3. 在控制台运行 Clipboard 可能会报错。

~

~

~ 本文完,感谢阅读!

~

学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!

我是〖编程三昧〗的作者 隐逸王,我的公众号是『编程三昧』,欢迎关注,希望大家多多指教!

你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!

知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!

相关推荐

Python操作Word文档神器:python-docx库从入门到精通

Python操作Word文档神器:python-docx库从入门到精通动动小手,点击关注...

Python 函数调用从入门到精通:超详细定义解析与实战指南 附案例

一、函数基础:定义与调用的核心逻辑定义:函数是将重复或相关的代码块封装成可复用的单元,通过函数名和参数实现特定功能。它是Python模块化编程的基础,能提高代码复用性和可读性。定义语法:...

等这么长时间Python背记手册终于来了,入门到精通(视频400集)

本文毫无套路!真诚分享!前言:无论是学习任何一门语言,基础知识一定要扎实,基础功非常的重要,找一个有丰富编程经验的老师或者师兄带着你会少走很多弯路,你的进步速度也会快很多,无论我们学习的目的是什么,...

图解Python编程:从入门到精通系列教程(附全套速查表)

引言本系列教程展开讲解Python编程语言,Python是一门开源免费、通用型的脚本编程语言,它上手简单,功能强大,它也是互联网最热门的编程语言之一。Python生态丰富,库(模块)极其丰富,这使...

Python入门教程(非常详细)从零基础入门到精通,看完这一篇就够

本书是Python经典实例解析,采用基于实例的方法编写,每个实例都会解决具体的问题和难题。主要内容有:数字、字符串和元组,语句与语法,函数定义,列表、集、字典,用户输入和输出等内置数据结构,类和对象,...

Python函数全解析:从入门到精通,一文搞定!

1.为什么要用函数?函数的作用:封装代码,提高复用性,减少重复,提高可读性。...

Python中的单例模式:从入门到精通

Python中的单例模式:从入门到精通引言单例模式是一种常用的软件设计模式,它保证了一个类只有一个实例,并提供一个全局访问点。这种模式通常用于那些需要频繁创建和销毁的对象,比如日志对象、线程池、缓存等...

【Python王者归来】手把手教你,Python从入门到精通!

用800个程序实例、5万行代码手把手教你,Python从入门到精通!...

Python从零基础入门到精通:一个月就够了

如果想从零基础到入门,能够全职学习(自学),那么一个月足够了。...

Python 从入门到精通:一个月就够了

要知道,一个月是一段很长的时间。如果每天坚持用6-7小时来做一件事,你会有意想不到的收获。作为初学者,第一个月的月目标应该是这样的:熟悉基本概念(变量,条件,列表,循环,函数)练习超过30个编...

Python零基础到精通,这8个入门技巧让你少走弯路,7天速通编程!

Python学习就像玩积木,从最基础的块开始,一步步搭建出复杂的作品。我记得刚开始学Python时也是一头雾水,走了不少弯路。现在回头看,其实掌握几个核心概念,就能快速入门这门编程语言。来聊聊怎么用最...

神仙级python入门教程(非常详细),从0到精通,从看这篇开始!

python入门虽然简单,很多新手依然卡在基础安装阶段,大部分教程对一些基础内容都是一带而过,好多新手朋友,对一些基础知识常常一知半解,需要在网上查询很久。...

Python类从入门到精通,一篇就够!

一、Python类是什么?大家在生活中应该都见过汽车吧,每一辆真实存在、能在路上跑的汽车,都可以看作是一个“对象”。那这些汽车是怎么生产出来的呢?其实,在生产之前,汽车公司都会先设计一个详细的蓝图...

学习Python从入门到精通:30天足够了,这才是python基础的天花板

当年2w买的全套python教程用不着了,现在送给有缘人,不要钱,一个月教你从入门到精通1、本套视频共487集,本套视频共分4季...

30天Python 入门到精通(3天学会python)

以下是一个为期30天的Python入门到精通学习课程,专为零基础新手设计。课程从基础语法开始,逐步深入到面向对象编程、数据处理,最后实现运行简单的大语言模型(如基于HuggingFace...

取消回复欢迎 发表评论: