JS实现剪贴板加入自定义信息

在逛博客的时候经常会遇到好文章,特别是看到想保留下来的信息时,会用CTRL+C把它复制,就像这样:

image.png

我复制了一篇文章中选择的部分,然后CTRL+V粘贴:

image.png

可以看到,粘贴出来的内容在复制内容加了作者、链接等信息。

那么,这是怎么实现的呢?

copy

当用户通过浏览器UI启动复制操作并响应允许的document.execCommand('copy')调用时触发copy事件。

copy事件可作用于任何可被选中或可编辑的元素,如body、div、input、textarea等。因此,可以通过监听函数来监听copy事件:

document.addEventListener('copy', handler);

可以通过window.getSelection(0).toString()获取复制的内容。

function handler(e) {
    console.log(window.getSelection(0).toString()); //输出复制内容
}
image.png

当然,我们的目标不是输出复制的内容,而是修改内容。

clipboardData.setData()

调用setData(format, data)可以修改ClipboardEvent.clipboardData 事件的默认行为

调用setData(),就可以修改剪贴板的内容,当然必须把默认事件取消(必须的,如果没有取消复制出来的内容不会发生变化)。

  //修改handler,给复制的内容添加内容
  function handler(e) {
           e.preventDefault();
          var content = `${window.getSelection(0).toString()}\n作者:路一直在_走` ;
          if(e.clipboardData) {
              e.clipboardData.setData('text/plain',  content);
          }
          else if(window.clipboardData){
              return window.clipboardData.setData("text", content);
          }
  }

现在复制然后输出看看效果:

image.png

如果忘记取消默认事件,结果是内容不会修改:

image.png

以下是来自MDN的介绍:

事件的默认行为与事件的来源和事件处理函数相关:
1.如果默认事件没有取消,就复制到选区(如果有选中内容)到剪切板;
2.如果取消了默认事件,但是调用了setData()方法:就复制clipboardData的内容到到剪切板;
3.如果取消了默认行为,而且没有调用setData()方法,就没有任何行为。

使用

既然知道了原理,现在我们在本地把掘金的添加内容去掉。打开掘金某个页面,在控制台输入以下代码:

document.addEventListener('copy', function(e) {
    e.preventDefault(); 
    //原封不动的输出
    e.clipboardData.setData('text/plain', window.getSelection(0).toString()); 
})

看看复制效果:

image.png

我们已经完美的去掉掘金添加的自定义内容。

同样,打开百度文库(你会发现复制了之后没内容),输入上述代码,可以实现复制粘贴(注意输出的内容不会保留格式)。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,871评论 1 32
  • 本节介绍各种常见的浏览器事件。 鼠标事件 鼠标事件指与鼠标相关的事件,主要有以下一些。 click 事件,dblc...
    许先生__阅读 7,535评论 0 4
  • # 先放图 很酷吧,相信经常在网上复制粘贴的人应该不陌生,我也是经历过,觉得很神奇,所以就寻思着是不是也在自己的...
    ipso阅读 5,081评论 0 2
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 9,961评论 0 5
  • 个人博客:https://yeaseonzhang.github.io 花了半个多月的时间,终于又把“JS红宝书”...
    Yeaseon阅读 5,734评论 2 23

友情链接更多精彩内容