最近工做中须要在前端页面中使用代码完成剪贴板的读写,网上搜索了下相应的资料,记录下...html
这个功能有两个办法一个是js方式,一个是使用flash前端
1、JS方法git
一、复制github
首先复制的过程分为两步曲,不管是使用手工仍是代码,先来看看手工的浏览器
a、使用光标选中内容 b、经过ctrl + c 进行复制安全
其实在代码端也是同样,以此用这个步骤来,html代码以下this
1 <html> 2 <head> 3 <title></title> 4 </head> 5 <body> 6 <input id="content" value="我是内容君" /> 7 </body> 8 </html>
上面ID为content的input,其中的内容就是咱们要复制的spa
第一步:选中它,代码以下插件
1 var range = document.createRange(); 2 range.selectNode(document.getElementById("content")); 3 window.getSelection().addRange(range);
而后就是这样的效果code
第二步:执行ctrl + c的操做
1 document.execCommand("copy");
代码就一行,返回值为true 表示成功
二、读取
这个也就是ctrl + v的功能了,只有一行代码
1 window.getSelection().toString();
效果以下
三、校验兼容性
因为安全相关考虑,不少浏览器都不支持在浏览器中操做剪贴板,因此为了兼容性,能够直接在浏览器中使用以下代码
1 document.execCommand("copy");
若是返回true,则表示浏览器支持,若是返回false则表示不支持
2、使用flash插件
flash这边权限比较大,能够完成复制粘贴的过程,可是也有很大的局限性,好比移动端就不支持flash,而后就是IE和火狐也不支持。
这边的demo使用的是zeroclipboard,git上的网页是https://github.com/zeroclipboard/zeroclipboard,官方demo和效果图以下
1 <html> 2 <body> 3 <button id="copy-button" data-clipboard-text="Copy Me!" title="Click to copy me.">Copy to Clipboard</button> 4 <script src="ZeroClipboard.js"></script> 5 <script src="main.js"></script> 6 </body> 7 </html>
var client = new ZeroClipboard( document.getElementById("copy-button") ); client.on( "ready", function( readyEvent ) { // alert( "ZeroClipboard SWF is ready!" ); client.on( "aftercopy", function( event ) { // `this` === `client` // `event.target` === the element that was clicked event.target.style.display = "none"; alert("Copied text to clipboard: " + event.data["text/plain"] ); } ); } );
差很少就是以上效果,可是我以为仍是不咋地,毕竟前端只是在浏览器中写的代码,并非一个彻底的C/S程序.....总之在浏览器中进行剪切板上的操做没有十全十美的。。。。。
搞定!!!!!!