这篇文章发布于 2010年08月17日,星期二,21:01,归类于 Graphic相关, JS实例。 阅读 105519 次, 今日 5 次 28 条评论
by zhangxinxu from http://www.zhangxinxu.com
本文地址:http://www.zhangxinxu.com/wordpress/?p=1037
补充于2018-01-01: 现在,基本上各大浏览器都支持了Clipboard API,虽然都是部分支持,但是基本文字复制等是OK的,所以本文内容过时。
一、单纯的js复制文字到剪切板较啰嗦
单纯的js复制文字到剪切板较啰嗦,由于考虑到安全性等原因,使用类似点击按钮这类复制文字内容的操作往往多有限制,例如IE浏览器下可以使用类似下面的方法复制一段文字到剪切板:
if(window.clipboardData) { window.clipboardData.clearData(); window.clipboardData.setData("text", "这是复制的文字"); }
结果执行的时候会有类似于下面的警戒提示:
至于其他浏览器,使用js实现也是比较啰嗦的,貌似好需要对浏览器进行一些设置,例如火狐Firefox浏览器被需要在浏览器地址栏输入’about:config’并回车,然后将’signed.applets.codebase_principal_support’设置为’true’才行,显然,不是个什么好方法。
所以,总的来看,使用js实现文字等内容的复制不是个好方法。
二、使用Flash做媒介轻松实现复制
既然,js实现文字的复制有点啰哩吧嗦的,我们可以转向其他的方法,例如JavaScript的近亲,ActionScript。一般而言,Flash是不存在兼容性的问题,只有支持与不支持。在AS3下,实现文字复制的方法有几个,我这里使用的是:
Clipboard.generalClipboard.setData(ClipboardFormats.TEXT_FORMAT, "这里是复制的文字内容");
很简单吧。现在有些麻烦的是与页面js的传参与交互。
AS3下获取外部传递的参数,可以使用:
var paramObj:Object = LoaderInfo(this.root.loaderInfo).parameters;
然后通过paramObj[“参数名”]就可以获得外部具体的参数了。
我们还需要给js一个回调,告诉使用者是否复制成功。可以使用:
ExternalInterface.call("js方法");
我们可以使用flashvars将要复制的文字传给Flash,通过Flash讲文字复制到剪切板上,同时回调给页面上的js。
然后,还有一点,由于安全性的原因,后来的Flash版本只支持点击事件以及键盘事件的复制,所以考虑到兼容性,我决定使用Flash按钮触发复制文字内容到剪切板。同时考虑到扩展性,所以按钮图片从外部使用Loader类调用。于是,我们总共需要两个参数,一是要复制的文字内容,二是按钮图片路径。
关于Flash接受参数,复制,回调等我都已经写好了,您所要所的就是在js脚本上设置些参数就好了,具体使用见下面。
三、js+flash(cs3)实现复制文字内容到剪切板
本实例我的是使用SWFObject2.0脚本转载Flash,关于SWFObject2.0,您可以参见网易的“SWFObject2.0: 基于Javascript的Flash媒体版本检测与嵌入模块”这篇文章,对于此脚本的使用里面有着非常详细的介绍。
具体步骤如下,
1.调用SWFObject2.0脚本,如下:
<script src="http://libs.baidu.com/swfobject/2.2/swfobject.js" type="text/javascript"></script>
我上面的这个swfobject脚本是由Dreamweaver生成的。
说明:因外链惊人,使用百度CDN公共库上的swfobject.js
, 原JS我置空了!
2. 给设定Flash的一些参数,假设我们要复制的值来自一个id为“zxxTestArea”的文本域,则一些设置如下:
var copyCon = document.getElementById("zxxTestArea").value; var flashvars = { content: encodeURIComponent(copyCon), uri: '../image/flash_copy_btn.png' }; var params = { wmode: "transparent", allowScriptAccess: "always" };
其中,flashvars中content指的是要复制的文字内容,uri是按钮图片的路径。params是设置Flash本身的一些属性,其中wmode不是必须的,但是allowScriptAccess是需要的,跨域处理安全沙箱等问题需要。
3. 传参并显示Flash
swfobject.embedSWF("../js/clipboard.swf", "forLoadSwf", "52", "25", "9.0.0", null, flashvars, params);
上面参数分别表示的是“flash的地址”,“用以装载并替换的HTML节点id”,“flash的宽”,“flash的高”,“flash版本”,“flash Player更新安装的swf调用地址”,“传给flash的参数”,“flash本身的一些参数”。
例如页面上有这么段HTML:
<span id="forLoadSwf"></span>
则此span标签就会被替换成flash,id也赋予给flash。
4. 回调给js
我在swf文件中给了js一个回调方法,方法名为“copySuccess”,例如:
function copySuccess(){ //flash回调 alert("复制成功!"); }
查看具体实际的效果,您可以狠狠地点击这里:js+flash(cs3)复制文字到剪切板demo
下载
关于此flash文件以及demo页面我已经打包成zip文件了,您可以狠狠地点击这里:zxx_clipboard.zip(右键-[目标|链接]另存为)
四、其他一些说明
1、我已经设置了舞台元素大小不随着flash大小改变而拉伸,同时按钮图片左上角显示,所以,您可以放心大胆的将swf的高宽设置成按钮图片的高宽。
2、可能是自己多事,我给按钮添加了一个透明度改变的hover效果,也就是移到flash装载的图片按钮上时,此按钮透明度为变成80%,移出时又变成100%透明度。
3、由于使用语调用都非常简单明了,不像同样采用flash交互的uploadify插件复杂,所以,这里没有将其插件化。
4、参数名以及回调函数的名称都是固定的,如果您使用其他的参数名则不会有效果的。其中您可以在回调的copySuccess方法添加一些更加人性化的提示方式。
5、demo页面第二个文本域是方便您测试的,可以随时通过粘贴的方式检测是否确实复制成功。
6、就这些,谢谢!
本文为原创文章,转载请注明来自张鑫旭-鑫空间-鑫生活[http://www.zhangxinxu.com]
本文地址:http://www.zhangxinxu.com/wordpress/?p=1037
(本篇完)
- IE6下png背景不透明问题的综合拓展 (0.482)
- 不同CSS布局实现与文字鼠标选择的可用性 (0.220)
- js写的打方块打飞机小游戏 (0.197)
- 博客内嵌flash音乐播放器代码、下载与使用 (0.183)
- 利用剪切板JS API优化输入框的粘贴体验 (0.110)
- 直接剪切板粘贴上传图片的前端JS实现 (0.110)
- JS复制文字到剪切板的极简实现及扩展 (0.110)
- jQuery-很酷的弹出层效果js插件 (0.084)
- 翻译 - 逐渐消失的Flash网站 (0.070)
- JavaScript实现图片幻灯片滚动播放动画效果 (0.042)
- 检测DOM尺寸变化JS API ResizeObserver简介 (RANDOM - 0.006)
function copyPhonenumber(phonenum){
var num = phonenum;
var flashvars = {
content: encodeURIComponent(phonenum),
uri: ‘/js/copyflash/flash_copy_btn.png’
};
var params = {
wmode: “transparent”,
allowScriptAccess: “always”
};
swfobject.embedSWF(“/js/copyflash/clipboard.swf”, “forLoadSwf”, “52”, “25”, “9.0.0”, null, flashvars, params);
}
function copySuccess(){
//flash回调
alert(“复制成功!”);
}
现在都使用开源的clipboard.js
回调函数不起作用怎么破?这个问题一直没有回复呢
这个是不兼容手机的吗?
额 有个小问题 这个只能复制一次到剪切板 第二次复制的时候还是第一次的内容 您提供的例子也一样
如果有多个内容需要复制呢,用id是不是有局限性啊
为什么必须服务器环境呢?
@云哥 估计安全性限制吧~
flas回调不起作用怎么破
你好,请问这样做的话可能被adblock给干掉,这种情况应该怎么处理呢
看了大神的代码, 试着写了个…
http://www.xuexb.com/demo/copy/copy.html
您好, 能不能提供下fla的文件啊, 最近在搞这东东
http://www.zhangxinxu.com/Scripts/swfobject_modified.js?ver=20100817空的
http://www.zhangxinxu.com/Scripts/swfobject_modified.js也是空的,什么情况
@xiamu 你好,被我清空了,因为外链流量惊人。您可以是使用下面这个链接:http://libs.baidu.com/swfobject/2.2/swfobject.js
回调函数不生效怎么办
很给力 谢谢
如果改变了文本类型,如何复制修改后的内容呢?
无效,不能在本地使用
下载到本地的回调不起作用啊…
好很好,非常好,百度+GG+N多博客看了相关的文章都没能很好的解决这个问题,楼主的方法完美解决,谢谢很想捐赠共免,由于是穷人,不小心误点了右上角300*300的图片,希望其他朋友不要误点哈
-_-
页面上多个调用,回调函数怎么搞
首先clipboard.swf做的剪切板很不错,兼容性很好。其次恭喜你把内容写死了,你添加几个字再复制试试。最后想请教一下达人,如果内容不是文字而是一个带样式的网页,应该怎么复制。
试试在本页面ctrl+a然后ctrl+c再找一个邮件或者word打开后ctrl+v。你会发现内容不但是文字,还有本页的样式,如何实现。请赐教,huan19890109.com@163.com
回调方法没起作用啊。
你讲的真的不错,看了你的讲解,可解决了我的一个大难题。
你好,这篇文章我转走啦..
http://www.open-lib.com/Forum/Read_72_1.action
已保留转载来源.
朋友,这个东东真不错! 给你赞一个.
现在我就把这个东西嵌到我的页面上了.呵呵!
真不错,DZ一类论坛程序用到这个复制功能
沙发啊。
以前挺自信地说CSS不难,看了你的文章之后,发现以前知道的都是牛毛,要学习的还有很多。
恩。要加油了。