js实现一键复制黏贴功能

clipboard

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <div id="codeBlock">
    <code>let a = 1;  <p style="color:red">
      https://www.jianshu.com/p/00344d68c0a2https://www.jian
    </p></code>
  </div>
  <button id="copy">复制</button>
  <button id="paste">黏贴</button>
</body>
<script>
  copy.addEventListener("click", () => {
    //给剪贴板中写入内容
    navigator.clipboard.writeText(codeBlock.innerHTML)
      .then(() => alert('复制成功'))
  })

  paste.addEventListener('click', () => {
    // 读取剪贴板的内容
    navigator.clipboard.readText()
      .then(text => { console.log(text), codeBlock.innerHTML = text + codeBlock.innerHTML })
  })  
</script>

</html>

选中文本的复制黏贴

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <div id="codeBlock">
    <code>let a = 1;  <p style="color:red">
      https://www.jianshu.com/p/00344d68c0a2https://www.jian
    </p></code>
  </div>
  <button id="copy">复制</button>
  <button id="paste">黏贴</button>
</body>
<script>
  function foo () {
    // 返回一个 Selection 对象,表示用户选择的文本范围或光标的当前位置。
    let selObj = window.getSelection();
    console.log(selObj);
    // Range 接口表示一个包含节点与文本节点的一部分的文档片段
    let selRange = selObj.getRangeAt(0);
    console.log(selRange);
    //Range.cloneContents() 返回一个 DocumentFragment,它是 Range 中所有的 Node 对象的副本。
    var docFragment = selRange.cloneContents();
    console.log(docFragment);
    var testDiv = document.createElement("div");
    testDiv.appendChild(docFragment);
    var selectHtml = testDiv.innerHTML;
    console.log(selectHtml);
    document.body.appendChild(testDiv)
  }
  // 注意 取消默认行为 我们鼠标右键的时候 一般是弹出 浏览器的 属性 刷新等等的那个菜单
  // 阻止默认行为 就没有那个菜单出来了
  document.addEventListener('contextmenu', function (e) {
    e.preventDefault();
    console.log('?')
  })
  document.addEventListener('mousedown', function (e) {
    if (e.button == 2) {
      console.log('?')
    } else if (e.button == 0) {
      // alert("你点了左键");
      console.log('?')
    } else if (e.button == 1) {
      alert("你点了滚轮");
    }
  })

</script>

</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值