博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【原创】ZeroClipboard的时代或许已经过去了
阅读量:6422 次
发布时间:2019-06-23

本文共 2775 字,大约阅读时间需要 9 分钟。

曾经,一个网页上要用Javascript实现网页内容的复制,其实是很麻烦的一件事情。虽然在这个问题上IE有其高大上的 window.clipboardData 方法支持直接复制指定内容,Firefox也早早的支持了 document.execCommand 命令,但是因为早期的Chrome不支持浏览器直接操作剪贴板,或者说不支持 document.execCommand 命令,让这一功能在兼容性上遇到了瓶颈。所以,聪明的开发者们开始走上“曲线救国”的道路:借助各大浏览器对Flash的支持,通过Javascript与Flash交互,将需要复制的内容传递到Flash中,再调用Flash操作剪切板的命令将内容复制到剪贴板,从而实现了兼容性极强的通过JS脚本复制网页文本的插件。这也就是的使命。

The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface.

ZeroClipboard曾盛极一时,而如今它的未来,恐怕令人担忧。随着HTML5的风靡,Flash在网页应用中的地位受到了极大的冲击,甚至有很多人都认为Flash正在慢慢淡出网页开发者的世界,而事实也的确如此。不仅如此,自Chrome 43版本发布,增加 document.execCommand 命令支持,更让ZeroClipboard的地位严重受到威胁。为什么这么说呢?下面我们一步一步来说明。

ZeroClipboard使用案例

通常情况下,ZeroClipord的应用场景大致是通过点击一个按钮复制一段指定的或用户输入的文本,HTML结构简单的做如下描述:

1 2 3 

下面配上ZeroClipboard的方法绑定就大功告成了!

1 (function(){2     var btn = document.getElementById('J_DoCopy'),3         text = document.getElementById('J_TextIn'),4         zc = new ZeroClipboard(btn);5     zc.on('beforecopy', function(e){6         zc.setText(text.value);7     });8 })();

我们预览页面,在文本框中输入任意字符,点击 Copy 按钮,文本框中输入的内容就被复制到剪贴板中了。我们可以在任意可写区域使用 Ctrl+V 或鼠标右键将内容进行粘贴。该案例可完美兼容各主流浏览器,包括IE6/7/8等骨灰级浏览器。

现在不使用ZeroClipboard我们也能实现

首先,我们保证页面结构不变,但不在引入ZeroClipboard插件:

1 2 

然后,我们使用 document.execCommamd 来对内容进行复制:

1 (function(){ 2     var btn = document.getElementById('J_DoCopy'), 3         text = document.getElementById('J_TextIn'); 4     btn.onclick = function(){ 5         var transfer = document.getElementById('J_CopyTransfer'); 6         if (!transfer) { 7             transfer = document.createElement('textarea'); 8             transfer.id = 'J_CopyTransfer'; 9             transfer.style.position = 'absolute';10             transfer.style.left = '-9999px';11             transfer.style.top = '-9999px';12             document.body.appendChild(transfer);13         }14         transfer.value = text.value;15         transfer.focus();16         transfer.select();17         document.execCommand('Copy', false, null);18     };19 })();

接着,我们在浏览器中浏览,和使用ZeroClipboard时一样的去操作,效果是一样的。但是,这段代码的正确执行是有限制的,因为 document.execCommand 在Chrome中支持的比较晚,所以要求Chrome版本必须是43及以后。

最后,再补充说明一下,使用 document.execCommand 来实现复制内容时,过渡被复制内容的 textarea 标签(即:动态创建的那个textarea标签),在复制可输入区域(input:text,textarea)的内容时并不是必须的,可以直接简化为:

1 (function(){ 2     var btn = document.getElementById('J_DoCopy'), 3         text = document.getElementById('J_TextIn'); 4     btn.onclick = function(){ 5         text.focus(); 6         text.select(); 7         document.execCommand('Copy', false, null); 8         text.blur(); 9     };10 })();

考虑到实际使用中,我们可能需要复制一些非编辑区域提供的内容(比如:一个a标签的链接地址等),所以增加了一个过渡的texearea,似乎更保险,更灵活一些。

此外,我再测试过程中,曾试图将过渡的那个textarea设置为不可见的 visibility:hidden; ,却发现复制功能失效了,所以这里需要注意一下...

作者博客:

转载于:https://www.cnblogs.com/mawuhen/p/4882104.html

你可能感兴趣的文章
JAVA常见算法题(十七)
查看>>
GUI鼠标相关设置
查看>>
使用 <Iframe>实现跨域通信
查看>>
闭包--循序学习
查看>>
项目实战之集成邮件开发
查看>>
解决C3P0在Linux下Failed to get local InetAddress for VMID问题
查看>>
1531 山峰 【栈的应用】
查看>>
巧用美女照做微信吸粉,你会做吗?
查看>>
wcf学习总结《上》
查看>>
ERROR (ClientException)
查看>>
WYSIWYG 网页在线编辑器比较表
查看>>
vss团队开发工具使用(个人学习心得)
查看>>
Load Balance 产品横向比较
查看>>
Java代理程序实现web方式管理邮件组成员
查看>>
【编译打包】tengine 1.5.1 SRPM
查看>>
看图说话:手动清除病毒文件流程
查看>>
一句话下拖库
查看>>
Deploy Office Communications Server 2007R2 Group Chat Server(二)
查看>>
在Cacti上实现MSN报警机制
查看>>
如何对C++虚基类构造函数
查看>>