移动端复制到粘贴板

移动端复制到粘贴板

前端时间做移动端碰到了关于复制到粘贴板的问题,搜到了下面两种方法,第一种亲测在手机上是有用的,第二种等待你萌在移动端测试是否成功告诉我哈!

法一

HTML:

<input type="text" id="text_input" /> <button type="button" id="copy_text">copy</button>

js:

`var inputElem = document.getElementById('text_input');
var btnElem = document.getElementById('copy_text');
btnElem.addEventListener('click', function() {
if(!document.execCommand) {
    console.error('copy unsupport');
    return;
 }
 inputElem.select();
 var result = document.execCommand('copy');
if(result) {
 console.log('copy success');
} else {
    console.error('copy fail');
}
});`

注意事项

  • 检测当前环境是否支持命令API,这一步不可或缺。
  • 浏览器环境不支持命令API,需要合理地提示用户手动进行复制操作。所以,一定不能设置文本元素 user-select: none;,这样会使文本不能被选择。
  • 表单元素必须处于被选中状态,即调用 inputElement.select() 方法,文本元素没有 select() 方法。
  • 经测试,不能使用 display: none; 或 visibility: hidden; 来隐藏表单元素。所以,只能将此表单元素,定位至可以见区域之外。
  • 必须表单元素有用,如果不是表单元素,建议新建input标签,然后把val赋给input,在进行操作。需要灵活实现

更多方案

  • clipboard.js:不依赖flash的一个插件。实现原理和上面的例子是类似的,使用插件可以简化很多开发工作。

引用:https://www.cnblogs.com/xianxianxxx/p/8056396.html

法二

    `<!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
         <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
        <script src="https://cdn.jsdelivr.net/clipboard.js/1.5.12/clipboard.min.js"></script>
        <title>移动端复制到粘贴板!</title>
    </head>
    <body>
    <p>哈哈<span id="target">你没看错,就是复制的这里</span></p>
    <button class="btn" data-clipboard-action="copy" data-clipboard-target="#target" id="copy_btn">
        复制按钮
    </button>
    </body>
    <script>
        $(document).ready(function(){
            var targetText=$("#target").text();
            var clipboard = new Clipboard('#copy_btn');
         
            clipboard.on('success', function(e) {
                console.info('Action:', e.action);
                console.info('Text:', e.text);
                console.info('Trigger:', e.trigger);
                alert("复制成功");
                e.clearSelection();
            });
        });
    </script>
    </html>`

转载于:https://www.cnblogs.com/pangwl/p/9044880.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值