示例一
HTML部分:
<input type="text" id="text_input" />
<button type="button" id="copy_text">copy</button>
js部分:
var inputElem = document.getElementById('text_input');
var btnElem = document.getElementById('copy_text');
btnElem.addEventListener('click', function() {
if(!document.execCommand) {
console.error('copy unsupport');
return;
}
inputElem.select();
var result = document.execCommand('copy');
if(result) {
console.log('copy success');
} else {
console.error('copy fail');
}
});
注意事项
- 检测当前环境是否支持命令API,这一步不可或缺。
- 浏览器环境不支持命令API,需要合理地提示用户手动进行复制操作。所以,一定不能设置文本元素
user-select: none;
,这样会使文本不能被选择。
- 表单元素必须处于被选中状态,即调用
inputElement.select()
方法,文本元素没有 select()
方法。
- 经测试,不能使用
display: none;
或 visibility: hidden;
来隐藏表单元素。所以,只能将此表单元素,定位至可以见区域之外。
- 必须表单元素有用,如果不是表单元素,建议新建input标签,然后把val赋给input,在进行操作。需要灵活实现
更多方案
原文见:https://github.com/xiaoyucoding/ask/issues/3