h5复制粘贴文字到剪切板

7 篇文章 0 订阅

需求:点击按钮时复制某段文字,转发时可以直接粘贴

<div id="copy-txt">
    前方高能预警,朋友圈文案在这里哦:**放大招,一分坐公交,还能领红包!
</div>
<button onclick="copyTXT()">复制</button>

HTML5 提供了复制功能的如下API:

  • document.createRange(): 创建选中容器,返回一个 range Object,支持移动端和 PC 端。
  • selectNode(DOM): 返回 range Object 上挂载的方法,用来添加选中元素,只能添加一个。
  • window.getSelection():用来获得当前选中的元素的内容。一般而言就是用鼠标选中页面上的内容。
  • addRange(range): 这个方法是挂载到 getSelection()方法下的,用来执行元素的选中。
function copyTXT(){
    var copyDOM = document.querySelector('#copy-txt'); //指定的DOM元素
    var range = document.createRange(); // 创建容器
    range.selectNode(copyDOM); // 选中需要复制的节点
    window.getSelection().addRange(range); // 执行选中元素
    var successful = document.execCommand('copy');// 执行 copy 操作
    try {
        var msg = successful ? 'successful' : 'unsuccessful';
        console.log('Copy was ' + msg);
    } catch(err) {
        console.log('unable to copy');
    }
    window.getSelection().removeAllRanges(); // 移除选中的元素
}

值得注意的是:以上复制的方法是不能自主执行的,也就是说需要某个事件去触发,比如点击,长按等。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值