zoukankan      html  css  js  c++  java
  • 复制文本事件(clipboard.min.js和原生JS复制)

    在项目中有这么一个需求,点击按钮复制一段文本,就像下图中的点击微信我们,弹出一个弹窗,点击好的跳转微信端添加好友。

    法一:(clipboard.min.js)

    需要使用到clipboard.min.js,下载链接:https://github.com/Superheroo/copy-text/tree/master

     代码如下:

    html部分:

    <div id="target">微信号</div>
    <button class="btn" data-clipboard-action="copy" data-clipboard-target="#target" id="copy_btn">
    <a class="copy" href="weixin://">复制按钮</a>
    </button>

    js部分:

    $(document).ready(function () {
    var targetText = $("#target").text();
    var clipboard = new ClipboardJS('#copy_btn');
    clipboard.on('success', function (e) {
    e.clearSelection();
    });
    });

     红色是点击处,黄色是点击时要复制的内容,橙色处不可少

    法二:(原生JS)

    在页面中添加一个 <textarea>,然后把它隐藏掉

    点击按钮的时候,先把 <textarea> 的 value 改为 <p> 的 innerText,然后复制 <textarea> 中的内容

    html:

    <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>

    js:

    <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("复制成功");
    }
    </script>

  • 相关阅读:
    CI登录验证
    兼容所有浏览器的JS动态显示当前日期时间
    Active Record 数据库模式-增删改查操作
    数据库链接的增操作举例
    CI框架获取post和get参数 CodeIgniter
    PHP日期操作类代码-农历-阳历转换、闰年、计算天数等
    根据两点间的经纬度计算距离
    Session 类
    mysql 查询优化规则
    php获取文件夹下面的文件列表和文件夹列表
  • 原文地址:https://www.cnblogs.com/james-L/p/9516194.html
Copyright © 2011-2022 走看看