JavaScript 实现复制功能

本文将学习如何通过 JavaScript 实现复制功能。

方法一:使用简单的 JavaScript 代码

我们可以使用 Clipboard API 的 Clipboard.writeText()Clipboard.write() 方法来用指定数据覆盖剪贴板内容。

实例

function myFunction() {
  /* 获取文本内容 */
  var copyText = document.getElementById(“myInput”);

  /* 选择复制内容 */
  copyText.select();
  copyText.setSelectionRange(0, 99999); /* 为移动设备设置 */

   /* 复制内容到文本域 */
  navigator.clipboard.writeText(copyText.value);

  /* 弹出已复制的内容 */
  alert(“复制的文本为: “ + copyText.value);
}

尝试一下 »

可以将复制完成后,使用更友好的方式来提示:

实例

function myFunction() {
  var copyText = document.getElementById(“myInput”);
  copyText.select();
  copyText.setSelectionRange(0, 99999);
  navigator.clipboard.writeText(copyText.value);
 
  var tooltip = document.getElementById(“myTooltip”);
  tooltip.innerHTML = “复制内容: “ + copyText.value;
}

function outFunc() {
  var tooltip = document.getElementById(“myTooltip”);
  tooltip.innerHTML = “点击按钮复制”;
}

尝试一下 »

方法二:使用第三方库 clipboard.js(推荐,兼容性强)

我们可以下载 clipboard.js 并引入项目:

当然,更简单的是直接使用国内 CDN 库:

实例

new ClipboardJS(‘#copyInput’, {
    text: function(trigger) {
        return document.getElementById(“myInput”).value;
    }
}).on(‘success’, function(e) {
   alert(“复制成功!!!”);
   e.clearSelection();
}).on(‘error’, function(e) {
    alert(‘Error!’);
});

尝试一下 »

clipboard.js 浏览器支持

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
  1. 免费下载或者VIP会员资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
  2. 提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或联络我们。
  3. 找不到素材资源介绍文章里的示例图片?
    对于会员专享、整站源码、程序插件、网站模板、网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
  4. 付款后无法显示下载地址或者无法查看内容?
    如果您已经成功付款但是网站没有弹出成功提示,请联系站长提供付款信息为您处理
  5. 购买该资源后,可以退款吗?
    源码素材属于虚拟商品,具有可复制性,可传播性,一旦授予,不接受任何形式的退款、换货要求。请您在购买获取之前确认好 是您所需要的资源

评论(0)

提示:请文明发言