JS实现复制粘贴功能

js实现网页内容的复制粘贴


示例代码如下(只兼容IE):

<meta charset="utf-8">
<script>
	
    function readTxt(){
  	alert(window.clipboardData.getData("text"));
    }
  
    function setTxt(){
  	var t=document.getElementById("txt");
  	t.select();
  	window.clipboardData.setData('text',t.createTextRange().text);
    }
</script>
<input name="txt" value="测试">
<input type="button" value="复制" οnclick="setTxt()">
<input type="button" value="读取" οnclick="readTxt()">


主要就是window.clipboardData      的使用。


上面方法不兼容Firefox、Chrome  ,意味着要抛弃这个简单的方法了。下面给个间接的实现方式,


现在浏览器种类也越来越多,诸如 IE、Firefox、Chrome、Safari等等,因此现在要实现一个js复制内容到剪贴板的小功能就不是一件那么容易的事了。

     在FLASH 9 时代,有一个通杀所有浏览器的js复制内容到剪贴板的方案

    这个方案是一个最流行的方法: 著名的Clipboard Copy解决方案  利用一个clipboard.swf作为桥梁,复制内容到剪贴板。
    原理是:创建一个隐藏的flash文件,同时给给flash的变量FlashVars 赋值“clipboard=..”,通过这个赋值flash就会把复制的内容放到剪贴板。这个方法兼容IE、Firefox、Opera、chrome、 Safari,真可谓“万能”的解决方案。浏览器Flash的安装率非常高,这几乎是一个完美的解决方案。

JS部分:
<script type="text/javascript"> 
  var clipboardswfdata;
  var setcopy_gettext = function(){
    clipboardswfdata = document.getElementById('test_text').value;
    //alert(clipboardswfdata);
    window.document.clipboardswf.SetVariable('str', clipboardswfdata);
  }
  var floatwin = function(){
    alert('复制成功!');
  //document.getElementById('clipinner').style.display = 'none';
  }
</script>

HTML部分:
<textarea id="test_text" rows="15" cols="100">文本內容</textarea>
<div id="clipboard_content"> 
  <div class="my_clip_button"><span class="clipinner" id="clipinner">複製代碼到剪貼簿
    <embed name="clipboardswf" class="clipboardswf" id="clipboardswf" οnmοuseοver="setcopy_gettext()" devicefont="false" src="./_clipboard.swf" menu="false" allowscriptaccess="sameDomain" swliveconnect="true" wmode="transparent" type="application/x-shockwave-flash" height="20" width="100">
    </span>
  </div> 
</div>

    clipboard.swf 的下载地址: _clipboard.rar.rar

     但是 Flash 10 时代,上面的方法已经不行了。
    因为flash10中规定了只有在swf上进行了真实的操作(比如鼠标点击)才能访问剪切板,而上述方法只是使用了一个隐藏的swf文件,通过javascript操作flash的剪贴板,用户并没有对swf文件进行真实的操作,因此这个方法也就失效了。

    那么如何解决这个“真实操作”的问题呢?可以使用一个JavaScript库: Zero Clipboard ,利用这个js库可以支持利用flash 10 实现复制到剪贴板。这个方法原理是在一个透明的flash(对用户来说是不可见的)上覆盖一个dom元素比如button或div,当点击这个dom时,实际点击的是flash,从而访问flash的剪贴板。

    飘易 拿来我调试好的小例子:
<html>
<head>
<title>Zero Clipboard Test</title>
<script type="text/javascript" src="ZeroClipboard.js"></script>
<script language="JavaScript">
  var clip = null;  
  function $(id) { return document.getElementById(id); }  
  function init() {
   clip = new ZeroClipboard.Client();
   clip.setHandCursor(true);  
   clip.addEventListener('mouseOver', function (client) {
    // update the text on mouse over
    clip.setText( $('fe_text').value );
   });
  
   clip.addEventListener('complete', function (client, text) {
    //debugstr("Copied text to clipboard: " + text );
    alert("该地址已经复制,你可以使用Ctrl+V 粘贴。");
   });

   clip.glue('clip_button', 'clip_container' );
  }
</script>
</head>

<body onLoad="init()">
<input id="fe_text" cols=50 rows=5 value=复制内容文本1 >
<span id="clip_container"><span id="clip_button"><b>复制</b></span></span>
</body>
</html>

    飘易提供的例子下载: zeroclipboard.rar

    调试时请上传到网站,本地直接打开flash会出错的,没权限。zeroClipboard.js文件里moviePath属性是falsh的地址,就是目录下的那个ZeroClipboard.swf存放的地址位置。

    这种js复制内容到剪贴板的方案可支持浏览器:Firefox / IE / opera / chorme / safari 所有浏览器!




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值