click
event listener).<textarea>
element, fill it with the supplied data and add it to the HTML document.Selection.getRangeAt()
to store the selected range (if any).Document.execCommand('copy')
to copy to the clipboard.<textarea>
element from the HTML document.Selection().addRange()
to recover the original selected range (if any).const copyToClipboard = 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);
}
};
copyToClipboard('Lorem ipsum'); // 'Lorem ipsum' copied to clipboard.
Subscribe to get resources directly to your inbox. You won't receive any spam! ✌️