支持多浏览器(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);
}
}


具体的应用,可以参考脚本之家的代码。

标签:浏览器,剪切板,复制
0
投稿

猜你喜欢

  • 针对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
  • 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
  • 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
  • ThinkPHP框架下微信支付功能总结踩坑笔记

    2024-05-02 17:13:41
  • 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
  • asp之家 网络编程 m.aspxhome.com