JavaScript实现复制内容到粘贴板代码

作者:philips 时间:2024-04-25 13:14:01 

最近做了一个前端项目,其中有需求:通过button直接把input或者textarea里的值复制到粘贴板里。下面小编把我实现思路及代码分享给大家,大家可以直接引入项目中。

具体代码如下所示:


function copyToClipboard(elem) {
// create hidden text element, if it doesn't already exist
var targetId = "_hiddenCopyText_";
var isInput = elem.tagName === "INPUT" || elem.tagName === "TEXTAREA";
var origSelectionStart, origSelectionEnd;
if (isInput) {
// can just use the original source element for the selection and copy
target = elem;
origSelectionStart = elem.selectionStart;
origSelectionEnd = elem.selectionEnd;
} else {
// must use a temporary form element for the selection and copy
target = document.getElementById(targetId);
if (!target) {
var target = document.createElement("textarea");
target.style.position = "absolute";
target.style.left = "-9999px";
target.style.top = "0";
target.id = targetId;
document.body.appendChild(target);
}
target.textContent = elem.textContent;
}
// select the content
var currentFocus = document.activeElement;
target.focus();
target.setSelectionRange(0, target.value.length);
// copy the selection
var succeed;
try {
succeed = document.execCommand("copy");
} catch(e) {
succeed = false;
}
// restore original focus
if (currentFocus && typeof currentFocus.focus === "function") {
currentFocus.focus();
}
if (isInput) {
// restore prior selection
elem.setSelectionRange(origSelectionStart, origSelectionEnd);
} else {
// clear temporary content
target.textContent = "";
}
return succeed;
}

我们可以这样直接调用这个方法:


copyToClipboard(document.getElementById("name"));

这样id为name的值进入了粘贴板了。

关于JavaScript实现复制内容到粘贴板代码小编就给大家介绍到这里,希望对大家有所帮助!

标签:js,复制,粘贴板
0
投稿

猜你喜欢

  • javascript学习随笔(编写浏览器脚本 Navigator Scripting )

    2024-04-28 09:49:39
  • MySQL数据库优化之分表分库操作实例详解

    2024-01-20 10:33:53
  • python入门for循环嵌套理解学习

    2021-03-01 21:42:16
  • Linux下mysql新建账号及权限设置方法

    2024-01-22 21:38:07
  • python生成器的使用方法

    2021-12-03 22:40:49
  • python如何修改装饰器中参数

    2021-08-18 15:28:27
  • 正视WEB标准,一本全面的标准参考书

    2009-05-30 16:36:00
  • PyTorch一小时掌握之图像识别实战篇

    2023-01-28 00:08:01
  • ASP平台如何打造金牌英文网站

    2008-04-10 08:47:00
  • python如何求解两数的最大公约数

    2021-01-16 07:38:18
  • css+js实现部分区域高亮可编辑遮罩层

    2024-02-25 08:49:23
  • 教你用Python下载抖音无水印视频

    2022-11-18 06:08:42
  • Python模块学习 datetime介绍

    2023-08-15 16:01:18
  • Django学习之静态文件与模板详解

    2022-12-13 13:19:58
  • python使用paramiko实现ssh的功能详解

    2023-03-29 04:10:34
  • python Flask 装饰器顺序问题解决

    2022-09-30 09:16:42
  • Python实现线程状态监测简单示例

    2023-12-07 20:31:25
  • Pytorch的安装过程之pip、conda、Docker容器安装

    2021-05-20 00:07:51
  • 使用matplotlib创建Gif动图的实现

    2021-03-09 11:32:02
  • 如何通过Django使用本地css/js文件

    2022-04-28 22:04:33
  • asp之家 网络编程 m.aspxhome.com