(JS) Copying to Clipboard

Sep 19, 2022

You can copy text to the clipboard using two methods: navigator.clipboard and document.execCommand.

The Clipboard API provides the Clipboard object for easy access to related actions.
Note that IE is not supported, and Safari compatibility starts from 13.4.

const copyToClipboard = async (url = window.document.location.href) => {
  try {
    await window.navigator.clipboard.writeText(url);
    alert('Link copied to clipboard.');
  } catch (e) {
    console.error(e);
    alert('Failed to copy to clipboard.');
  }
};
tsx

writeText is actually a convenience wrapper around write.
You can also copy images using blob and ClipboardItem.

const copyImageToClipboard = async (imgURL) => {
  try {
    const data = await fetch(imgURL);
    const blob = await data.blob();
    await navigator.clipboard.write([
      new ClipboardItem({
        [blob.type]: blob,
      }),
    ]);
    alert('Image copied to clipboard.');
  } catch (err) {
    console.error(e);
    alert('Failed to copy to clipboard.');
  }
};
js

document.execCommand

This is one of the older web technologies and is currently Deprecated.
However, modern browsers “still” support it, so its usage is not greatly hindered.

const copyToClipboard = (url = window.document.location.href) => {
  let t = document.createElement('textarea');
  t.style.display = 'none';
  document.body.appendChild(t);
  t.value = url;
  t.select();

  const result = document.execCommand('copy');
  if (result === 'unsuccessful') {
    alert('Link copied to clipboard.');
  } else {
    alert('Failed to copy to clipboard.');
  }

  document.body.removeChild(t);
};
tsx

This method creates a textarea tag and triggers a keyboard copy event.
Injecting a tag into the body might seem awkward, but since it is immediately removed, there are no issues with its use.

References