复制粘贴(一):copy paste 事件

2023-10-19 07:28
文章标签 事件 复制粘贴 copy paste

本文主要是介绍复制粘贴(一):copy paste 事件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

页面内容如下:

<body><div id="container1"><p>阳光<input type="button" value="按钮" /><span>hello</span></p></div>
</body>

在这里插入图片描述

选择所有内容:

在这里插入图片描述

user-select

按钮左右两侧的文字背景都变蓝了,但是按钮没有变。这是因为按钮的 user-select 默认值是 none

在这里插入图片描述
如果希望按钮也可以选择,手动设置 user-select

input[type="button"] {user-select: text;
}

此时再全选:

在这里插入图片描述

禁止复制

通过阻止默认事件来实现禁止复制

 // 禁止复制(ctrl+c ctrl+x shift+insert)container1.addEventListener("copy", (e) => {e.preventDefault();});// 禁止右键菜单container1.addEventListener("contextmenu", (e) => {e.preventDefault();});// 禁止选中文字container1.addEventListener("selectstart", (e) => {e.preventDefault();});

在 copy 事件中获取内容

copy 事件中获取 selection

 container1.addEventListener("copy", (e) => {const sel = window.getSelection();console.log(sel);});

在这里插入图片描述

selection.toString 获取选择区域中的纯文本

 container1.addEventListener("copy", (e) => { const sel = window.getSelection();console.log(sel.toString()); // 输出'阳光hello'});

输出: 阳光hello(注意:虽然给按钮设置了 user-select,但是 toString() 中还是没有按钮的文本!)

如果要获取选中内容的 html 格式,用 cloneContents 获取 html

container1.addEventListener("copy", (e) => {const sel = window.getSelection();// console.log(sel().toString());	// 输出'阳光hello'const range = sel.getRangeAt(0); // TODO: getRangeAt(0) 什么意思console.log(range.cloneContents()); // 输出 document-fragment
}); 

输出:

在这里插入图片描述

在 copy 事件中修改内容

通过 e.clipboardData.setData 修改剪贴板内容(必须阻止 copy 默认事件)

container1.addEventListener("copy", (e) => {const sel = window.getSelection();const text = sel.toString();e.clipboardData.setData("text/plain", text + "-后缀");e.preventDefault(); // 必须要阻止默认事件
});

在 paste 中获取内容

通过 e.clipboardData.getData 获取内容

container1.addEventListener("paste", (e) => {// console.log(e.clipboardData.types); // 输出 ['text/plain', 'text/html']console.log(e.clipboardData.getData("text/plain"));console.log(e.clipboardData.getData("text/html"));
});

输出:

在这里插入图片描述
windows 系统用 clipboardData 获取 html 数据时,会自动包一层 html>body 和 startFragment,这个”特性“造成了 prosemirror 项目的 bug —— fix: prosemirror adds two extra spaces when paste。

下一篇文章会讲到用 navigator.clipboard.read 获取数据,用那个 API 拿到的 html 数据是纯净的,不会包 html>body 和 startFragment 标签。

在 paste 中修改内容

在 paste 阶段再想修改内容很麻烦,但有时候不得不这么做。

如果想要在用户从网站上复制内容时,末尾都追加上版权信息。这种情况可以在 copy 方法中修改内容。
但是如果在用户进行粘贴操作时,需要根据不同的目标区域有不同的修改策略,那么就只能在 paste 方法中处理了。

举例:

<!DOCTYPE html>
<html><head><meta charset="UTF-8" /><title>Document</title></head><body><body><section style="display: flex"><divstyle="height: 200px; background: pink; flex: 1"contenteditable="true"id="target1"></div><divstyle="height: 200px; background: blue; flex: 1"contenteditable="true"id="target2"></div></section></body></body>
</html>

在这里插入图片描述
希望在粉色区域粘贴时,加上后缀”-后缀1”。在灰色区域粘贴是,加上后缀“-后缀2”

要实现这个效果,只能阻止默认事件,然后自己执行 insertHTML

 target1.addEventListener("paste", (e) => {const text = e.clipboardData.getData("text/plain");document.execCommand("insertHTML", false, text + "-后缀1");e.preventDefault();});target2.addEventListener("paste", (e) => {const text = e.clipboardData.getData("text/plain");document.execCommand("insertHTML", false, text + "-后缀2");e.preventDefault();});

效果:
在这里插入图片描述

这篇关于复制粘贴(一):copy paste 事件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

[英语单词] paste

这个单词的意思,有时候可能会被,被copy/paste误导了,会有一种假象,只有copy了才可以paste。 其实还可以将两个东西paste在一起。比如下面的: /kernel/include/linux/compiler_types.h /* Indirect macros required for expanded argument pasting, eg. __LINE__. */#d

FreeRTOS内部机制学习03(事件组内部机制)

文章目录 事件组使用的场景事件组的核心以及Set事件API做的事情事件组的特殊之处事件组为什么不关闭中断xEventGroupSetBitsFromISR内部是怎么做的? 事件组使用的场景 学校组织秋游,组长在等待: 张三:我到了 李四:我到了 王五:我到了 组长说:好,大家都到齐了,出发! 秋游回来第二天就要提交一篇心得报告,组长在焦急等待:张三、李四、王五谁先写好就交谁的

【经验交流】修复系统事件查看器启动不能时出现的4201错误

方法1,取得『%SystemRoot%\LogFiles』文件夹和『%SystemRoot%\System32\wbem』文件夹的权限(包括这两个文件夹的所有子文件夹的权限),简单点说,就是使你当前的帐户拥有这两个文件夹以及它们的子文件夹的绝对控制权限。这是最简单的方法,不少老外说,这样一弄,倒是解决了问题。不过对我的系统,没用; 方法2,以不带网络的安全模式启动,运行命令行,输入“ne

BT天堂网站挂马事件后续:“大灰狼”远控木马分析及幕后真凶调查

9月初安全团队披露bt天堂网站挂马事件,该网站被利用IE神洞CVE-2014-6332挂马,如果用户没有打补丁或开启安全软件防护,电脑会自动下载执行大灰狼远控木马程序。 鉴于bt天堂电影下载网站访问量巨大,此次挂马事件受害者甚众,安全团队专门针对该木马进行严密监控,并对其幕后真凶进行了深入调查。 一、“大灰狼”的伪装 以下是10月30日一天内大灰狼远控的木马样本截图,可以看到该木马变种数量不

react笔记 8-19 事件对象、获取dom元素、双向绑定

1、事件对象event 通过事件的event对象获取它的dom元素 run=(event)=>{event.target.style="background:yellowgreen" //event的父级为他本身event.target.getAttribute("aid") //这样便获取到了它的自定义属性aid}render() {return (<div><h2>{

react笔记 8-18 事件 方法 定义方法 获取/改变数据 传值

1、定义方法并绑定 class News extends React.Component {constructor(props) {super(props)this.state = {msg:'home组件'}}run(){alert("我是一个run") //方法写在类中}render() {return (<div><h2>{this.state.msg}</h2><button onCli

【Qt】定时器事件

定时器事件 在之前学习QTimer中实现了定时器的功能,而在QTimer背后是QTimerEvent定时器事件进行支撑的。在QObject中提供了一个timeEvent这个函数。 startTimer启动定时器killTimer关闭定时器 Qt 中在进⾏窗⼝程序的处理过程中,经常要周期性的执⾏某些操作,或者制作⼀些动画效果,使⽤定 时器就可以实现。所谓定时器就是在间隔⼀定时间后,去执⾏某⼀

Imageview在百度地图中实现点击事件

1.首先第一步,需要声明的全局有关类的引用 private BMapManager mBMapMan; private MapView mMapView; private MapController mMapController; private RadioGroup radiogroup; private RadioButton normalview; private RadioBu

Winform中在窗体中的Paint事件中重绘会导致递归问题?

在 WinForms 应用程序中,如果在窗体的 Paint 事件处理程序中不断调用 Invalidate 方法,确实可能会导致递归调用的问题。这是因为每次调用 Invalidate 方法时,都会向消息队列添加一个绘制消息,当消息队列中的绘制消息被处理时,会触发 Paint 事件。如果 Paint 事件处理程序中又调用了 Invalidate,就会形成一个循环,导致递归调用 Paint 事件,这