• 原生js实现复制文本到粘贴板


    项目中经常会遇到点击按钮复制订单号、订单id等内容到粘贴板中的需求。可是通常我们都是用Ctrl + c或右击复制的,别操心,js也是有复制命令的,那就是document.execCommand('copy'); 这个命令会将选中的内容复制到粘贴板中,那岂不是还需要选中?别急input和textarea元素有一个select()方法,这个方法可以帮我们自动选中。于是就有了下面的代码,复制过去试试吧!

    function copy(text) {
    	var input = document.createElement('input');
    	input.setAttribute('readonly', 'readonly'); // 防止手机上弹出软键盘
    	input.setAttribute('value', text);
    	document.body.appendChild(input);
    	// input.setSelectionRange(0, 9999);
    	input.select();
    	var res = document.execCommand('copy');
    	document.body.removeChild(input);
    	return res;
    }
    

      思路分析:

    1. 创建input或textarea,因为这两个DOM具有select方法,可以选中内容(document.execCommand('copy')复制内容必要条件);
    2. 给input赋值为需要赋值的内容
    3. 将DOM添加到文档中
    4. 选中输入框中的值(也就是要复制的值)
    5. 执行复制命令
    6. 最后别忘了从文档中移除DOM元素
    7. 此函数最后返回了复制是否成功的结果(true/false,document.execCommand('copy')本身会返回true/false),你可以做相应的交互提示等。

     后面实践发现,当要复制的内容中含有tab符号或者换行的符号时,复制的结果就不是想要的结果了,因为input不支持换行,然后textarea是支持的,所以,对这个函数修改了一下,下面这个目前使用起来还没遇到问题,有问题的小伙伴欢迎留言评论

    /**
     * @auth zhaodesheng
     * @param {String} text 需要复制的内容
     * @return {Boolean} 复制成功:true或者复制失败:false  执行完函数后,按ctrl + v试试
    */
    function copy(text) {
        var textareaEl = document.createElement('textarea');
        textareaEl.setAttribute('readonly', 'readonly'); // 防止手机上弹出软键盘
        textareaEl.value = text;
        document.body.appendChild(textareaEl);
        textareaEl.select();
        var res = document.execCommand('copy');
        document.body.removeChild(textareaEl);
        console.log("复制成功");
        return res;
    }
    

      

  • 相关阅读:
    052-159
    ConfigurationManager.AppSettings["SiteUrl"] DataIDField="Id"
    for循环提交Grid中的数据,防止乱码的问题
    d_YWZC_new_Main中如何发送邮件
    EditGrid中的用法
    extjs中的suspendLayouts、suspendEvents、resumeEvents、resumeLayouts;
    如何保存复选框中的值,以及如何显示复选框中的值
    提交时,若Grid列表框中没有数据,如何利用js提示
    上传文件的时候,如何只获取选中的文件名
    复选框的全选和取消全选功能(来自华三,使用js代码实现)
  • 原文地址:https://www.cnblogs.com/zhaodesheng/p/11464934.html
Copyright © 2020-2023  润新知