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