【技术】JS 操作剪贴板

2024-06-17 05:04
文章标签 技术 操作 js 剪贴板

本文主要是介绍【技术】JS 操作剪贴板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JS 操作剪贴板

  • 1、原生 JS 操作剪贴板复制文本
  • 2、原生 JS 操作剪贴板读取图片实现异步上传
    • navigator 对象
    • 监听粘贴事件
  • 3、剪贴板插件

1、原生 JS 操作剪贴板复制文本

在博客类网站看到一段代码,想复制,如果代码量比较大,选中内容复制会比较麻烦。多数情况下会在代码右上角看到一个复制按钮,点击即可复制代码,是如何实现的呢?

准备一个按钮,样式可以自定,绑定一个单击事件

<button type="button" onclick="copyVal()">复制</button>
<div class="content">这里是一段文字...</div>

编写 copyVal() 方法

<script>function copyVal(){// 获取内容的组件let content = document.querySelector(".content");// 选中组件内容window.getSelection().selectAllChildren(content);// 执行拷贝命令document.execCommand("Copy");}
</script>

2、原生 JS 操作剪贴板读取图片实现异步上传

navigator 对象

navigator 对象在使用时有弊端,仅在安全域环境下生效。安全域环境是指:https 请求、localhost、127.0.0.1 作为请求的情况。如果是 IP 地址访问则会出现 navigator.clipboard 是 underfind 的情况。原因是浏览器的安全限制,不希望代码随意访问用户的剪贴板。不过可以采用另外一种方案解决。

async function getImageFromClipboard() {try {// 异步读取剪贴板内容let clipboardItems = clipboardItems = await navigator.clipboard.read();// 遍历剪贴板for (const clipboardItem of clipboardItems) {// 获取剪贴板内容类型for (const type of clipboardItem.types) {// 图片格式判断if (type === 'image/png' || type === 'image/jpeg') {// 获取图片元数据const blob = await clipboardItem.getType(type);// 创建文件读取对象const reader = new FileReader();// 文件读取成功reader.onload = (e) => {// 创建图片文件对象const img = new Image();// 把图片添加到页面元素中$(".img-box")[0].appendChild(img);};// 将数据读取为数据URLreader.readAsDataURL(blob);/* 异步上传图片 */// 构建文件对象,传递 blob 参数const file = new File([blob], "pasted-image." + type.split("/")[1], {type: type,});// 构建表单对象var formData = new FormData();formData.append('files', file);formData.append('language', $("#language").val());ajaxUpload(formData);/* 异步上传图片 */} else {alert("剪贴板最近内容不是图片!");return;}}}} catch (error) {console.error('Failed to read clipboard contents:', error);}
}
/*** 通过表单提交*/
function ajaxUpload(data){$.ajax({url: "/upload",type: "post",cache: false,data: data,processData: false,// 不处理数据contentType: false, // 不设置内容类型dataType: "json",success: function (data) {console.log("请求成功:", data);// 这里是请求成功的业务逻辑},error: function () {console.log("请求失败!")}});
}

监听粘贴事件

navigator 对象的使用弊端可以曲线救国,通过监听粘贴事件实现相关业务。

document.onpaste = function(event){try {// 获取剪贴板的元素集合var items = (event.clipboardData || event.originalEvent.clipboardData).items;// 遍历剪贴板元素for (var i = 0 ; i < items.length ; i++) {var item = items[i];// 判断图片类型if (item.type.indexOf("image") != -1) {// 元素转换为文件对象var file = item.getAsFile();/* 图片展示到页面 */// 创建读取文件组件(JS内置对象)var fr = new FileReader();// 读取文件fr.readAsDataURL(file);// 当数据读取完成的触发一个事件fr.onload = function () {// 获取文件数据var url = fr.result;let img = `<img src="${url}" id="showImg"/>`;// 把图片展示到页面$(".img-box").append(img);}/* 图片展示到页面 *//* 异步上传图片 */// 构建表单对象var formData = new FormData();// 表单添加文件,注意第一个参数是传递数据的 key,也就是 input file 的 name 属性的值formData.append('files', file);ajaxUpload(formData);/* 异步上传图片 */break;}}} catch (error) {console.error('Failed to read clipboard contents:', error);}
}

3、剪贴板插件

因为代码兼容问题,可以使用剪贴板插件:https://clipboardjs.com/

这篇关于【技术】JS 操作剪贴板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1068542

相关文章

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

Java中的Schema校验技术与实践示例详解

《Java中的Schema校验技术与实践示例详解》本主题详细介绍了在Java环境下进行XMLSchema和JSONSchema校验的方法,包括使用JAXP、JAXB以及专门的JSON校验库等技术,本文... 目录1. XML和jsON的Schema校验概念1.1 XML和JSON校验的必要性1.2 Sche

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str