起初是使用浏览器提供了 copy 命令 。javascript
document.execCommand("copy")
若是是输入框,能够经过 select() 方法,选中输入框的文本,而后调用 copy 命令,将文本复制到剪切板。可是 select() 方法只对 <input> 和 <textarea> 有效,对于 <p> 就很差用了java
function copyUrl() { $("#copyinput").select(); // 选择对象 document.execCommand("Copy"); // 执行浏览器复制命令 alert("已复制到剪贴板!"); }
可是#copyinput不能隐藏(display:none or visibility:hidden or type="hidden"),我想要的是点击一个按钮就能复制隐藏控件的值。因此找到了clipboard.js 优秀!git
如下是clipboard.js 的使用方法。github
HTML: <input type="hidden" id="content" value="复制的内容"/> <input type="button" id="copyUrl" value="请点击我复制"/> JS: var clipboard2 = new ClipboardJS('#copyUrl', { text: function() { return $("#content").val(); } }); clipboard2.on('success', function(e) { console.log("已复制到剪贴板!"); }); clipboard2.on('error', function (e) { });
兼容如下浏览器版本浏览器
下载连接:https://github.com/zenorocha/clipboard.jscode