Clipboard: write()-Methode

Baseline 2024
Newly available

Since June 2024, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.

Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.

Die write() Methode des Clipboard Interfaces schreibt beliebige Daten in die Zwischenablage, wie z.B. Bilder, und erfüllt das zurückgegebene Promise, sobald der Vorgang abgeschlossen ist. Dies kann verwendet werden, um Ausschneiden- und Kopieren-Funktionen zu implementieren.

Die Methode kann theoretisch beliebige Daten schreiben (im Gegensatz zur writeText(), die nur Text schreiben kann). Browser unterstützen üblicherweise das Schreiben von Text, HTML und PNG-Bilddaten – siehe Browser-Kompatibilität für weitere Informationen.

Syntax

js
write(data)

Parameter

data

Ein Array von ClipboardItem Objekten, die die Daten enthalten, die in die Zwischenablage geschrieben werden sollen.

Rückgabewert

Ein Promise, das aufgelöst wird, wenn die Daten in die Zwischenablage geschrieben wurden. Beachten Sie, dass, wenn das zugrunde liegende Betriebssystem das Speichern mehrerer nativer Zwischenablage-Elemente in der Systemzwischenablage nicht unterstützt, nur das erste ClipboardItem im Array gespeichert wird.

Das Versprechen wird abgelehnt, wenn es der Zwischenablage nicht gelingt, in die Zwischenablage zu schreiben.

Ausnahmen

NotAllowedError DOMException

Wird ausgelöst, wenn das Schreiben in die Zwischenablage nicht erlaubt ist.

Sicherheitsüberlegungen

Das Schreiben in die Zwischenablage kann nur in einem sicheren Kontext durchgeführt werden.

Zusätzliche Sicherheitsanforderungen werden im Abschnitt Sicherheitsüberlegungen des API-Übersichtsthemas behandelt.

Beispiele

Text in die Zwischenablage schreiben

Diese Beispiel-Funktion ersetzt den aktuellen Inhalt der Zwischenablage mit einem angegebenen String, wenn eine Taste gedrückt wird. Beachten Sie, dass Sie für diesen speziellen Fall ebenso gut Clipboard.writeText() verwenden könnten.

js
button.addEventListener("click", () => setClipboard("<empty clipboard>"));

async function setClipboard(text) {
  const type = "text/plain";
  const blob = new Blob([text], { type });
  const data = [new ClipboardItem({ [type]: blob })];
  await navigator.clipboard.write(data);
}

Die setClipboard() Methode beginnt mit der Erstellung eines neuen Blob Objekts. Dieses Objekt wird benötigt, um ein ClipboardItem Objekt zu konstruieren, das an die Zwischenablage gesendet wird. Der Blob Konstruktor nimmt den Inhalt, den wir kopieren möchten, und seinen Typ entgegen. Dieses Blob Objekt kann aus vielen Quellen abgeleitet werden, z. B. einem Canvas.

Als nächstes erstellen wir ein neues ClipboardItem Objekt, in das der Blob zum Senden an die Zwischenablage eingefügt wird. Der Schlüssel des an den ClipboardItem Konstruktor übergebenen Objekts gibt den Inhaltstyp an, der Wert gibt den Inhalt an. Dann wird write() mit await aufgerufen. Ein try..catch Block könnte verwendet werden, um etwaige Fehler beim Schreiben der Daten abzufangen.

Canvas-Inhalte in die Zwischenablage schreiben

Dieses Beispiel zeichnet ein blaues Rechteck auf das Canvas. Sie können auf das Rechteck klicken, um den Inhalt des Canvas als Bild in die Zwischenablage zu kopieren, und dann ein anderes Element auswählen und den Inhalt aus der Zwischenablage einfügen.

HTML

Das HTML definiert nur unser <canvas> Element und das <div> Element mit der ID target, wo das Canvas-Bild eingefügt wird.

html
<canvas id="canvas" width="100" height="100"></canvas>

<div id="target">Paste here.</div>
js
const logElement = document.querySelector("#log");
function log(text) {
  logElement.innerText = `${logElement.innerText}${text}\n`;
  logElement.scrollTop = logElement.scrollHeight;
}

JavaScript

Zuerst definieren wir eine async Funktion, um ein Canvas in einen Blob zu kopieren. Dies fasst die alte Callback-basierte HTMLCanvasElement.toBlob() Methode in eine intuitivere, auf Promise basierende Funktion zusammen.

js
// Async/await method replacing toBlob() callback
async function getBlobFromCanvas(canvas) {
  return new Promise((resolve, reject) => {
    canvas.toBlob((blob) => {
      if (blob) {
        resolve(blob);
      } else {
        reject(new Error("Canvas toBlob failed"));
      }
    });
  });
}

Als nächstes richten wir unser Canvas ein und fügen einen Ereignislistener für das click Ereignis hinzu.

Wenn Sie auf das blaue Rechteck klicken, überprüft der Code zuerst, ob die Zwischenablage Daten vom Typ "image/png" unterstützt. Falls ja, wird das Canvas mit dem angezeigten Rechteck in einen Blob kopiert, und dann wird der Blob zu einem ClipboardItem hinzugefügt und in die Zwischenablage geschrieben.

js
const canvas = document.getElementById("canvas");

// Set up canvas
const ctx = canvas.getContext("2d");
ctx.fillStyle = "cornflowerblue";
ctx.fillRect(0, 0, 100, 100);

canvas.addEventListener("click", copyCanvasContentsToClipboard);
const target = document.getElementById("target");

async function copyCanvasContentsToClipboard() {
  if (ClipboardItem.supports("image/png")) {
    // Copy canvas to blob
    try {
      const blob = await getBlobFromCanvas(canvas);
      // Create ClipboardItem with blob and it's type, and add to an array
      const data = [new ClipboardItem({ [blob.type]: blob })];
      // Write the data to the clipboard
      await navigator.clipboard.write(data);
      log("Copied");
    } catch (error) {
      log(error);
    }
  } else {
    log("image/png is not supported");
  }
}

Beachten Sie, dass die Unterstützung von PNG-Dateien in der Zwischenablage Teil der Spezifikation ist, sodass wir die Überprüfung mit ClipboardItem.supports() oben eigentlich nicht benötigen (sie gibt immer true zurück). Die Überprüfung wäre nützlicher in Fällen, in denen wir einen optionalen Dateityp abrufen oder eine Ressource mit unbekanntem Typ vorab auswählen.

Dann definieren wir einen Ereignislistener für paste Ereignisse auf einem Element, wo wir die Zwischenablageinhalte als Bild anzeigen wollen. Die FileReader API ermöglicht es uns, den Blob mit der Methode readAsDataUrl zu lesen und ein <img> Element mit den Canvas-Inhalten zu erstellen:

js
target.addEventListener("paste", (event) => {
  const items = (event.clipboardData || window.clipboardData).items;
  const blob = items[0].getAsFile();
  const reader = new FileReader();

  reader.addEventListener("load", (event) => {
    const img = new Image();
    img.src = event.target.result;
    target.appendChild(img);
  });

  reader.readAsDataURL(blob);
});

Ergebnis

Das Ergebnis wird unten gezeigt. Klicken Sie zuerst auf das blaue Quadrat und wählen Sie dann den Text "Paste here" und verwenden Sie die spezifischen Tastenkombinationen Ihres Betriebssystems, um aus der Zwischenablage einzufügen (zum Beispiel Ctrl+V unter Windows).

Spezifikationen

Specification
Clipboard API and events
# dom-clipboard-write

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch