支持多浏览器(IE、Firefox、Opera)剪切板复制函数_脚本之家修正版
时间:2024-05-03 15:08:06
需要注意的是,firefox下必须要设置下
signed.applets.codebase_principal_support
在 firefox浏览器地址栏输入about:config 过滤器中输入signed.applets.codebase_principal_support双击设置为true即可支持。因为firefox默认情况下是不支持脚本操作剪切板的。
因为只是什么都不支持的浏览器才是最安全的浏览器。
<script> function copyToClipboard(txt) { if(window.clipboardData) { window.clipboardData.clearData(); window.clipboardData.setData("Text",txt); alert("复制成功!"); } else if(navigator.userAgent.indexOf("Opera")!= -1) { window.location = txt; } else if (window.netscape) { try { netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect"); } catch (e) { alert("您的firefox安全限制限制您进行剪贴板操作,请打开'about:config'将signed.applets.codebase_principal_support'设置为true'之后 重试,具体可以参考https://www.jb51.net/article/16705.htm"); return false; } var clip = Components.classes["@mozilla.org/widget/clipboard;1"].createInstance(Components.interfaces.nsIClipboard); if (!clip) return; var trans = Components.classes["@mozilla.org/widget/transferable;1"].createInstance(Components.interfaces.nsITransferable); if (!trans) return; trans.addDataFlavor('text/unicode'); var str = new Object(); var len = new Object(); var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString); var copytext = txt; str.data = copytext; trans.setTransferData("text/unicode",str,copytext.length*2); var clipid = Components.interfaces.nsIClipboard; if (!clip) return false; clip.setData(trans,null,clipid.kGlobalClipboard); } } copyToClipboard("https://www.jb51.net"); </script>
下面是ie firefox 读取剪切板中的信息的方法
function getClipboard()
{
if (window.clipboardData)
{
return (window.clipboardData.getData('text'));
}
else
{
if (window.netscape)
{
try
{
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
var clip = Components.classes["@mozilla.org/widget/clipboard;1"].createInstance(Components.interfaces.nsIClipboard);
if (!clip)
{
return;
}
var trans = Components.classes["@mozilla.org/widget/transferable;1"].createInstance(Components.interfaces.nsITransferable);
if (!trans)
{
return;
}
trans.addDataFlavor("text/unicode");
clip.getData(trans, clip.kGlobalClipboard);
var str = new Object();
var len = new Object();
trans.getTransferData("text/unicode", str, len);
}
catch (e)
{
alert("您的firefox安全限制限制您进行剪贴板操作,请打开'about:config'将signed.applets.codebase_principal_support'设置为true'之后重试,相对路径为firefox根目录/greprefs/all.js");
return null;
}
if (str)
{
if (Components.interfaces.nsISupportsWString)
{
str = str.value.QueryInterface(Components.interfaces.nsISupportsWString);
}
else
{
if (Components.interfaces.nsISupportsString)
{
str = str.value.QueryInterface(Components.interfaces.nsISupportsString);
}
else
{
str = null;
}
}
}
if (str)
{
return (str.data.substring(0, len.value / 2));
}
}
}
return null;
}
下面是 ie,firefox下 写入剪切板的代码
copy2Clipboard=function(txt){
if(window.clipboardData){
window.clipboardData.clearData();
window.clipboardData.setData("Text",txt);
}
else if(navigator.userAgent.indexOf("Opera")!=-1){
window.location=txt;
}
else if(window.netscape){
try{
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
}
catch(e){
alert("您的firefox安全限制限制您进行剪贴板操作,请打开'about:config'将signed.applets.codebase_principal_support'设置为true'之后重试,相对路径为firefox根目录/greprefs/all.js");
return false;
}
var clip=Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
if(!clip)return;
var trans=Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
if(!trans)return;
trans.addDataFlavor('text/unicode');
var str=new Object();
var len=new Object();
var str=Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
var copytext=txt;str.data=copytext;
trans.setTransferData("text/unicode",str,copytext.length*2);
var clipid=Components.interfaces.nsIClipboard;
if(!clip)return false;
clip.setData(trans,null,clipid.kGlobalClipboard);
}
}
具体的应用,可以参考脚本之家的代码。
标签:浏览器,剪切板,复制
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
针对google Chrome的 CSS hacks
2009-11-30 12:45:00
轻松掌握 MySQL的数字类型以及建库策略
2008-11-27 16:09:00
js实现文字列表无缝滚动效果
2024-04-19 10:16:12
python简单实现9宫格图片实例
2021-10-22 13:23:25
![](https://img.aspxhome.com/file/2023/6/81726_0s.png)
Python中实现字符串类型与字典类型相互转换的方法
2021-07-01 20:37:25
ElementUI日期选择器时间选择范围限制的实现
2024-04-09 11:00:28
Python 异常处理实例详解
2021-10-14 05:36:39
Pytorch中torch.cat()函数举例解析
2023-01-09 15:42:15
![](https://img.aspxhome.com/file/2023/7/86357_0s.jpg)
python3实现域名查询和whois查询功能
2023-09-19 19:35:12
轻松掌握 SQL Server 2000数据库的构架
2009-02-05 15:50:00
python中urllib.unquote乱码的原因与解决方法
2023-08-24 14:56:43
python虚拟环境virtualenv的使用教程
2021-03-08 00:50:17
vue后台管理添加多语言功能的实现示例
2024-04-29 13:08:22
Python Timer和TimerFPS计时工具类
2022-06-13 12:48:38
![](https://img.aspxhome.com/file/2023/4/105314_0s.png)
ThinkPHP框架下微信支付功能总结踩坑笔记
2024-05-02 17:13:41
![](https://img.aspxhome.com/file/2023/7/129837_0s.png)
python+adb+monkey实现Rom稳定性测试详解
2023-02-06 07:46:00
简单介绍Python中的len()函数的使用
2022-08-19 16:27:02
django model object序列化实例
2022-07-03 14:55:24
Python实现简单求解给定整数的质因数算法示例
2021-05-27 09:23:08
python递归调用中的坑:打印有值, 返回却None
2023-11-02 23:07:42