JS实现一键复制

 更新时间:2022年07月01日 15:13:42   作者:莎莉哇  
这篇文章主要为大家详细介绍了js实现点击按钮复制文本,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

原生js实现点击按钮复制文本,供大家参考,具体内容如下

最近遇到一个需求,需要点击按钮,复制 聊天记录的文本到剪切板

一、原理分析

浏览器提供了 copy 命令 ,可以复制选中的内容

document.execCommand("copy")

如果是输入框,可以通过 select() 方法,选中输入框的文本,然后调用 copy 命令,将文本复制到剪切板

但是 select() 方法只对 和 有效,对于就不好使

最后我的解决方案是,在页面中添加一个 ,然后把它隐藏掉点击按钮的时候,先把 的 value 改为的 innerText,然后复制 中的内容

二、代码实现

<style type="text/css">
   .wrapper {position: relative;}
   #input {position: absolute;top: 0;left: 0;opacity: 0;z-index: -10;}
</style>

<div class="wrapper">
   <p id="text">我把你当兄弟你却想着复制我?</p>
   <textarea id="input">这是幕后黑手</textarea>
   <button onclick="copyText()">copy</button>
</div>
<script type="text/javascript">
    function copyText() {
      var text = document.getElementById("text").innerText;
      var input = document.getElementById("input");
      input.value = text; // 修改文本框的内容
      input.select(); // 选中文本
      document.execCommand("copy"); // 执行浏览器复制命令
      alert("复制成功");
    }
    //或者
    function copyText(value) {
        // 创建元素用于复制
        var aux = document.createElement("input");

        // 设置元素内容
        aux.setAttribute("value", value);

        // 将元素插入页面进行调用
        document.body.appendChild(aux);

        // 复制内容
        aux.select();

        // 将内容复制到剪贴板
        document.execCommand("copy");

        // 删除创建元素
        document.body.removeChild(aux);

        //提示
        alert("复制内容成功:" + aux.value);
    }
  </script>

三、一键复制

分享一个自己工作中用到的一键复制方法

/**
 * 一键粘贴
 * @param  {String} id [需要粘贴的内容]
 * @param  {String} attr [需要 copy 的属性,默认是 innerText,主要用途例如赋值 a 标签上的 href 链接]
 *
 * range + selection
 *
 * 1.创建一个 range
 * 2.把内容放入 range
 * 3.把 range 放入 selection
 *
 * 注意:参数 attr 不能是自定义属性
 * 注意:对于 user-select: none 的元素无效
 * 注意:当 id 为 false 且 attr 不会空,会直接复制 attr 的内容
 */
copy (id, attr) {
    let target = null;

    if (attr) {
        target = document.createElement('div');
        target.id = 'tempTarget';
        target.style.opacity = '0';
        if (id) {
            let curNode = document.querySelector('#' + id);
            target.innerText = curNode[attr];
        } else {
            target.innerText = attr;
        }
        document.body.appendChild(target);
    } else {
        target = document.querySelector('#' + id);
    }

    try {
        let range = document.createRange();
        range.selectNode(target);
        window.getSelection().removeAllRanges();
        window.getSelection().addRange(range);
        document.execCommand('copy');
        window.getSelection().removeAllRanges();
        console.log('复制成功')
    } catch (e) {
        console.log('复制失败')
    }

    if (attr) {
        // remove temp target
        target.parentElement.removeChild(target);
    }
}

实现效果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解JavaScript中的属性和特性

    详解JavaScript中的属性和特性

    本文对JavaScript中对象的本质、对象与类的关系、对象与引用类型的关系;对象属性如何进行分类;属性中特性进行介绍。感兴趣的朋友可以看下
    2016-12-12
  • jQuery实现腾讯信用界面(自制刻度尺)样式

    jQuery实现腾讯信用界面(自制刻度尺)样式

    这篇文章主要介绍了jQuery实现腾讯信用界面(自制刻度尺)样式,下文还总结了关于jquery中extend的方法,需要的朋友可以参考下
    2017-08-08
  • webpack HappyPack实战详解

    webpack HappyPack实战详解

    这篇文章主要介绍了webpack HappyPack实战详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • JavaScript面试开发常用的知识点总结

    JavaScript面试开发常用的知识点总结

    这篇文章主要为大家详细总结了JavaScript面试开发常用的知识点,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • JavaScript实现二分查找实例代码

    JavaScript实现二分查找实例代码

    二分查找的前提为:数组、有序。这篇文章主要介绍了JavaScript实现二分查找实例代码,需要的朋友可以参考下
    2017-02-02
  • 基于JavaScript实现百叶窗动画效果不只单纯flas可以实现

    基于JavaScript实现百叶窗动画效果不只单纯flas可以实现

    看到这种百叶窗效果的动画,以为是用flash做的,下面通过本文给大家介绍基于JavaScript实现百叶窗动画效果,需要的朋友参考下吧
    2016-02-02
  • Javascript中的arguments与重载介绍

    Javascript中的arguments与重载介绍

    这篇文章主要介绍了Javascript中的arguments与重载介绍,本文讲解了Javscript 重载、Javascript arguments不是一个数组等内容,需要的朋友可以参考下
    2015-03-03
  • javascript实现超好看的3D烟花特效

    javascript实现超好看的3D烟花特效

    这篇文章主要为大家详细介绍了javascript实现超好看的3D烟花特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • JsonServer安装及启动过程图解

    JsonServer安装及启动过程图解

    这篇文章主要介绍了JsonServer安装及启动过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • pnpm install:ERR_PNPM_PEER_DEP_ISSUES Unmet peer dependencies

    pnpm install:ERR_PNPM_PEER_DEP_ISSUES Unmet p

    这篇文章主要为大家介绍了pnpm install:ERR_PNPM_PEER_DEP_ISSUES Unmet peer dependencies报错解决
    2023-06-06

最新评论