您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

JavaScript复制页面内容的三种方案(总结分享)

2024/3/31 21:46:43发布31次查看
本篇文章给大家带来了关于javascript的相关知识,主要为大家介绍了使用 js 复制页面内容的三种方案详解,有需要的朋友可以借鉴参考下,希望能够有所帮助。
【相关推荐:javascript视频教程、web前端】
现在有很多第三方插件能够实现 copy 功能,但如果让我们自己去做,我们知道如何去实现吗?
这篇文章介绍三种实现方案。
方式一:async clipboard api使用 async clipboard api
这种方式使用起来最简单,但兼容性不太好,而且要求比较多。
示例代码:
const promise = navigator.clipboard.writetext(newcliptext);
需要注意,方法的返回值是个 promise。并且使用此方法时,页面必须处于 focus 状态,否则会报错。
方式二:document.execcommand api使用 document.execcommand
此方法虽然警告被废弃,不再属于 web 标准,但历史因素较多,相信浏览器还会支持很久。
复制 dom 元素内容<p id="content">123456</p><button id="copybutton">复制</button>
复制 dom 元素的时候,需要额外使用到 selection api 和 range api。
developer.mozilla.org/en-us/docs/…
developer.mozilla.org/en-us/docs/…
示例代码:
const copybutton = document.getelementbyid('copybutton');const content = document.getelementbyid('content');copybutton.addeventlistener('click', function () { const selection = window.getselection(); const range = document.createrange(); // 设置选中内容 range.selectnodecontents(content); // 清空选中内容 selection.removeallranges(); // 添加选中内容 selection.addrange(range); document.execcommand('copy');});
selection 需要先清空再添加 range。
这里会有一个细节问题,点击复制按钮之后,被复制的内容处于选中状态,有些突兀。
解决方式是在复制完成之后调用 selection.removeallranges() 清空选中内容即可。
再考虑一种情况,用户在复制之前就选中了页面的部分内容。在复制完成之后,除了清空选中的复制内容,还需要还原用户在复制之前就选中的内容。
实现代码如下:
const copybutton = document.getelementbyid('copybutton');const content = document.getelementbyid('content');copybutton.addeventlistener('click', function () { const selection = window.getselection(); const range = document.createrange(); // 缓存用户选中的内容 const currentrange = selection.rangecount === 0 ? null : selection.getrangeat(0); // 设置文档片段 range.selectnodecontents(content); // 清空选中内容 selection.removeallranges(); // 将文档片段设置为选中内容 selection.addrange(range); try { // 复制到剪贴板 document.execcommand('copy'); } catch (err) { // 提示复制失败 } finally { selection.removeallranges(); if (currentrange) { // 还原用户选中内容 selection.addrange(currentrange); } }});
先缓存用户选中的内容,复制完成之后,再还原。
复制 input 元素内容使用 input 元素对象的 select 方法即可选中内容,无需创建 range 片段设置选中内容。
示例代码:
const copybutton = document.getelementbyid('copybutton');const inputel = document.getelementbyid('input');copybutton.addeventlistener('click', function () { const selection = window.getselection(); const currentrange = selection.rangecount === 0 ? null : selection.getrangeat(0); // 选中 input 内容 inputel.select(); // 复制到剪贴板 try { document.execcommand('copy'); } catch (err) { // 提示复制失败 // 。。。 } finally { selection.removeallranges(); if (currentrange) { // 还原用户选中内容 selection.addrange(currentrange); } }});
点击复制按钮,同样不会移除之前选中的内容。
方法三:覆写 copy 事件w3c.github.io/clipboard-a…
引用上面链接内的一段代码作为示例:
// overwrite what is being copied to the clipboard.document.addeventlistener('copy', function (e) { // e.clipboarddata is initially empty, but we can set it to the // data that we want copied onto the clipboard. e.clipboarddata.setdata('text/plain', '西炒蛋'); // this is necessary to prevent the current document selection from // being written to the clipboard. e.preventdefault();});
在页面复制任何内容,粘贴输出的内容都会是 “西炒蛋”。
【相关推荐:javascript视频教程、web前端】
以上就是javascript复制页面内容的三种方案(总结分享)的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product