“复制到剪贴板”是我们日常工作中最常用到的一种操作,几乎每天都有使用很多次,但JavaScript客户端API对这个功能只提供了非常有限的支持,有些老的API和老式的浏览器在你复制时会弹出讨厌的“你真的要这样做吗?”类似的确认框,非常不方便,不友好。在几年前我曾有一篇文章里谈论过用ZeroClipboard实现JavaScript剪贴板操作,虽然是可以实现,但有一个弊端,它使用的是flash技术,而如今,很多浏览器开始不支持flash技术,所以,我们需要不依赖flash技术的JavaScript方法来实现浏览器端的剪贴板操作。今天给大家介绍的就是用纯JavaScript实现的解决方案:clipboard.js。
这个clipboard.js 里提供的“复制的剪贴板”API非常的简洁方便,下面就是它的一些用法:
/* Textarea - Cut<textarea id="bar">hello</textarea><button class="copy-button" data-clipboard-action="cut" data-clipboard-target="#bar">Cut</button>*/var clipboard = new Clipboard('.copy-button');/* Input - Copy<input id="foo" value="hello" type="text"><button class="copy-button" data-clipboard-action="copy" data-clipboard-target="#foo">Copy</button>*/var clipboard = new Clipboard('.copy-button');
/* HTMLElement - Copy<div id="copy-target">hello</div><button class="copy-button" data-clipboard-action="copy" data-clipboard-target="#copy-target">Copy</button>*/var clipboard = new Clipboard('.copy-button');
Target
和Text
的用法// Contents of an elementvar clipboard = new Clipboard('.copy-button', { target: function() { return document.querySelector('#copy-target'); }});// A specific stringvar clipboard = new Clipboard('.copy-button', { text: function() { return 'clipboard.js is awesome!'; }});
var clipboard = new Clipboard('.btn');clipboard.on('success', function(e) { console.log(e);});clipboard.on('error', function(e) { console.log(e);});
联系客服