前端JS控制网页复制粘贴

    <script>
        (function() {
  document.addEventListener('copy',(e)=>{
    e.preventDefault();
    e.stopPropagation();
    console.info('触发复制事件');
    /** 
      返回一个Selection对象,表示用户选择的文本范围或光标的当前位置
      Selection.getRangeAt返回一个包含当前选区内容的区域对象
    */
    let text = window.getSelection().getRangeAt(0);
    let node = document.createElement('div');
    // cloneContents方法把范围(Range)的内容复制到一个DocumentFragment对象
    node.appendChild(window.getSelection().getRangeAt(0).cloneContents());
    /** 
       ClipboardEvent.clipboardData 属性保存了一个 DataTransfer 对象,这个对象可用于:
       描述哪些数据可以由 cut 和 copy 事件处理器放入剪切板,通常通过调用 setData(format, data) 方法;
       获取由 paste 事件处理器拷贝进剪切板的数据,通常通过调用 getData(format) 方法
    */
    e.clipboardData.setData("text", text+"\n'''\nhttps://www.cnblogs.com/3-wusen/\n欢迎访问我的博客\n'''");
    // console.log(node.innerHTML)
    // console.log(text)
    // if(e.clipboardData){
    //   e.clipboardData.setData("text/html", node.innerHTML);
    //   e.clipboardData.setData("text/plain",text);
    // }else if(window.clipboardData){
    //   return window.clipboardData.setData("text", text);
    // }
  })
}());
    </script>
View Code

 

posted @ 2021-06-29 14:44    阅读(320)  评论(0编辑  收藏  举报