Don’t let your dreams be dreams.

单击复制文字兼容各浏览器

单击复制文字的js。找了很久,由于之前没有接触过,完全不知道兼容ie及标准dom浏览器,不仅仅要通过js,而且需要flash的帮忙。clipboard.swf这个在网上都有下载.

ie允许访问剪贴板。window.clipboardData可以访问

但是标准dom。看了一些文章说的都是用flash设置隐藏。但是flash10是不支持。

但是,还有个方法是可行的,固记录一下,以下方法支持标准dom.

	(function () {
		
		window['Util'] = {
			CACHE:{},
			getText : function(){
		        return Util.CACHE.CLIPBOARD_TEXT;
		    },
		    successHide : function(){
		        alert("复制北海365网招聘邮件地址!");
		    },
			Copy : function (pStr,hasReturn, isdo) {

					var html = [];
					html.push('<object type="application/x-shockwave-flash" data="clipboard.swf?gettext=Util.getText&success=Util.successHide" width="50" height="40" style="position:relative;top:11px;left:-50px;" id="ff_clipboard_swf">');
					html.push('<param name="quality" value="high" />');
					html.push('<param name="allowScriptAccess" value="sameDomain" />');
					html.push('<param name="allowFullScreen" value="true" />');
					html.push('<param name="wmode" value="transparent" />');
					html.push('</object>');
					var yu=document.getElementById('copy').innerHTML;
					document.getElementById('copy').innerHTML=yu+html.join('');
					Util.CACHE.CLIPBOARD_TEXT = pStr;
				
			}
		}
		Util.Copy('zhaopin@beihai365.com ');

	})();

  

如果要兼容ie。还得加上

if (window.clipboardData) {
	window.clipboardData.setData("Text",pStr);
	Util.successHide();
}

  

最后这样能实现单击复制文字,并且兼容各浏览器。记住。swf的路径一定要对!如果不对是不出现手型的,这是特征。

	(function () {
		window['Util'] = {
			CACHE:{},
			getText : function(){
		        return Util.CACHE.CLIPBOARD_TEXT;
		    },
		    successHide : function(){
		        alert("复制北海365网招聘邮件地址!");
		    },
			Copy : function (pStr,hasReturn, isdo) {
				var copy=document.getElementById('copy');
				if (window.clipboardData) {
					copy.onclick=function(){
						window.clipboardData.setData("Text",pStr);
						Util.successHide();
					}
				} else {
					var html = [];
					html.push('<object type="application/x-shockwave-flash" data="clipboard.swf?gettext=Util.getText&success=Util.successHide" width="50" height="40" style="position:relative;top:11px;left:-50px;" id="ff_clipboard_swf">');
					html.push('<param name="quality" value="high" />');
					html.push('<param name="allowScriptAccess" value="sameDomain" />');
					html.push('<param name="allowFullScreen" value="true" />');
					html.push('<param name="wmode" value="transparent" />');
					html.push('</object>');
					var yu=copy.innerHTML;
					copy.innerHTML=yu+html.join('');
					Util.CACHE.CLIPBOARD_TEXT = pStr;
				}
			}
		}
		Util.Copy('zhaopin@beihai365.com ');

	})();

  

哎呀好饿,之后再整理。

 

posted on 2013-05-15 18:31  包田耘  阅读(152)  评论(0编辑  收藏  举报