zoukankan      html  css  js  c++  java
  • JS实现复制信息到剪贴板

    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()); //输出复制内容
    }
    
     

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

    clipboardData.setData()

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

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

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

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

    以下是来自MDN的介绍:

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

    使用

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

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

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

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

  • 相关阅读:
    [BZOJ5020] [THUWC 2017]在美妙的数学王国中畅游
    [BZOJ3876] [AHOI2014&JSOI2014]支线剧情
    [BZOJ5120] [2017国家集训队测试]无限之环
    [BZOJ2959] 长跑
    [BZOJ2502] 清理雪道
    SSM-MyBatis-08:Mybatis中SqlSession的commit方法为什么会造成事物的提交
    SSM-MyBatis-07:Mybatis中SqlSession的insert和delete底层到底做了什么
    SSM-MyBatis-06:Mybatis中openSession到底做了什么
    SSM-MyBatis-05:Mybatis中别名,sql片段和模糊查询加getMapper
    SSM-MyBatis-04:Mybatis中使用properties整合jdbc.properties
  • 原文地址:https://www.cnblogs.com/airen123/p/12367136.html
Copyright © 2011-2022 走看看