今天在做项目的时候遇到点击复制的一个功能,虽然原生js的点击复制只需要三行就搞定了,但是在angular里面并不生效,于是在网上找了半天,也没有找到答案,最后无意间看见了大漠老师的视频,才有所启发。
下面是原生的点击复制方法:
function copyUrl2(){
var copyInnerHTML = document.getElementById('invite_code');
copyInnerHTML.select();
document.execCommand('copy');
}
在下面是angular的复制:
function copyToClipboard(str) {
console.log(str)
const el = document.createElement('textarea');
el.value = str;
el.setAttribute('readonly', '');
el.style.position = 'absolute';
el.style.left = '-9999px';
document.body.appendChild(el);
const selected = document.getSelection().rangeCount > 0 ? document.getSelection().getRangeAt(0) : false;
el.select();
document.execCommand('copy');
document.body.removeChild(el);
if (selected) {
document.getSelection().removeAllRanges();
document.getSelection().addRange(selected);
}
}