Clipboard: read() 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.
* Some parts of this feature may have varying levels of support.
Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.
Die read()
Methode der Clipboard
-Schnittstelle fordert eine Kopie des Inhalts der Zwischenablage an und erfüllt das zurückgegebene Promise
mit den Daten.
Die Methode kann theoretisch beliebige Daten zurückgeben (im Gegensatz zu readText()
, die nur Text zurückgeben kann). Browser unterstützen häufig das Lesen von Text, HTML und PNG-Bilddaten.
Syntax
read()
read(formats)
Parameter
formats
Optional-
Ein optionales Objekt mit den folgenden Eigenschaften:
unsanitized
Optional-
Ein
Array
von Strings, das MIME-Typen von Datenformaten enthält, die beim Lesen von der Zwischenablage nicht bereinigt werden sollen.Bestimmte Browser können die Daten der Zwischenablage bereinigen, wenn sie gelesen werden, um zu verhindern, dass bösartige Inhalte in das Dokument eingefügt werden. Zum Beispiel entfernt Chrome (und andere auf Chromium basierende Browser) beim Lesen HTML-Daten
<script>
-Tags und andere potenziell gefährliche Inhalte. Verwenden Sie dasunsanitized
Array, um eine Liste von MIME-Typen anzugeben, die nicht bereinigt werden sollen.
Rückgabewert
Ein Promise
, das mit einem Array von ClipboardItem
-Objekten erfüllt wird, die den Inhalt der Zwischenablage enthalten.
Ausnahmen
NotAllowedError
DOMException
-
Wird ausgelöst, wenn das Lesen von der Zwischenablage nicht erlaubt ist.
Sicherheitsüberlegungen
Das Lesen von der Zwischenablage kann nur in einem sicheren Kontext erfolgen.
Zusätzliche Sicherheitsanforderungen sind im Sicherheitsüberlegungen-Abschnitt des API-Übersichtsthemas beschrieben.
Beispiele
Lesen von Bilddaten aus der Zwischenablage
Dieses Beispiel verwendet die read()
Methode, um Bilddaten von der Zwischenablage zu lesen und in ein <img>
-Element einzufügen.
HTML
<img id="source" src="butterfly.jpg" alt="A butterfly" />
<img id="destination" />
<button id="reload" type="button">Reload</button>
<p id="log"></p>
CSS
img {
height: 100px;
width: 100px;
margin: 0 1rem;
border: 1px solid black;
}
#reload {
display: block;
margin: 0 1rem;
}
JavaScript
Dieser Code bietet einen Mechanismus, um Fehler in das Element mit der ID log
zu protokollieren.
const logElement = document.querySelector("#log");
function log(text) {
logElement.innerText = `Error: ${text}`;
}
Wir fügen auch Code hinzu, um das Beispiel neu zu laden und zu löschen, wenn die Schaltfläche "Neu laden" gedrückt wird.
const reload = document.querySelector("#reload");
reload.addEventListener("click", () => {
window.location.reload(true);
});
Der restliche Code liest die Zwischenablage, wenn das Ziel-Element angeklickt wird, und kopiert die Bilddaten in das destinationImage
-Element.
Es protokolliert einen Fehler, wenn es nicht in der Lage ist, die read()
Methode zu verwenden, oder wenn die Zwischenablage keine Daten im PNG-Format enthält.
const destinationImage = document.querySelector("#destination");
destinationImage.addEventListener("click", pasteImage);
async function pasteImage() {
try {
const clipboardContents = await navigator.clipboard.read();
for (const item of clipboardContents) {
if (!item.types.includes("image/png")) {
throw new Error("Clipboard does not contain PNG image data.");
}
const blob = await item.getType("image/png");
destinationImage.src = URL.createObjectURL(blob);
}
} catch (error) {
log(error.message);
}
}
Ergebnis
Kopieren Sie das Schmetterlingsbild auf der linken Seite, indem Sie mit der rechten Maustaste auf das Bild klicken und "Bild kopieren" aus dem Kontextmenü wählen. Klicken Sie dann auf den leeren Rahmen auf der rechten Seite. Das Beispiel holt die Bilddaten aus der Zwischenablage und zeigt das Bild im leeren Rahmen an.
Hinweis: Falls erforderlich, gewähren Sie die Erlaubnis, um das Bild einzufügen.
Lesen von Daten aus der Zwischenablage
Dieses Beispiel verwendet die read()
Methode, um Daten aus der Zwischenablage zu lesen und das gespeicherte Datenformat im Protokoll anzuzeigen.
Dies unterscheidet sich von der vorherigen Version dadurch, dass es Text-, HTML- und BildClipboardItem
-Objekte (anstatt nur Bilder) anzeigt.
HTML
<img id="source_jpg" src="butterfly.jpg" alt="JPG butterfly image" />
<div id="destination">Click here to copy clipboard data.</div>
<button id="reload" type="button">Reload</button>
<p id="log"></p>
CSS
img {
height: 100px;
width: 100px;
margin: 0 1rem;
border: 1px solid black;
}
#destination {
min-height: 300px;
min-width: 90%;
margin: 0 1rem;
border: 1px solid black;
}
#reload {
display: block;
margin: 0 1rem;
}
JavaScript
Dieser Code bietet einen Mechanismus, um Fehler in das Element mit der ID log
zu protokollieren.
const logElement = document.querySelector("#log");
function log(text) {
logElement.innerText = `Error: ${text}`;
}
Wir fügen auch Code hinzu, um das Beispiel neu zu laden und zu löschen, wenn die Schaltfläche "Neu laden" gedrückt wird.
const reload = document.querySelector("#reload");
reload.addEventListener("click", () => {
window.location.reload(true);
});
Der restliche Code liest die Zwischenablage, wenn das Ziel-Element angeklickt wird, und zeigt jedes ClipboardItem
-Element zusammen mit seinem MIME-Typ an.
Es protokolliert einen Fehler, wenn es nicht in der Lage ist, die read()
Methode zu verwenden oder wenn die Zwischenablage einen anderen MIME-Typ enthält.
const destinationDiv = document.querySelector("#destination");
destinationDiv.addEventListener("click", pasteData);
async function pasteData() {
destinationDiv.innerText = ""; //Clear inner text
try {
const clipboardContents = await navigator.clipboard.read();
for (const item of clipboardContents) {
for (const mimeType of item.types) {
const mimeTypeElement = document.createElement("p");
mimeTypeElement.innerText = `MIME type: ${mimeType}`;
destinationDiv.appendChild(mimeTypeElement);
if (mimeType === "image/png") {
const pngImage = new Image(); // Image constructor
pngImage.src = "image1.png";
pngImage.alt = "PNG image from clipboard";
const blob = await item.getType("image/png");
pngImage.src = URL.createObjectURL(blob);
destinationDiv.appendChild(pngImage);
} else if (mimeType === "text/html") {
const blob = await item.getType("text/html");
const blobText = await blob.text();
const clipHTML = document.createElement("pre");
clipHTML.innerText = blobText;
destinationDiv.appendChild(clipHTML);
} else if (mimeType === "text/plain") {
const blob = await item.getType("text/plain");
const blobText = await blob.text();
const clipPlain = document.createElement("pre");
clipPlain.innerText = blobText;
destinationDiv.appendChild(clipPlain);
} else {
throw new Error(`${mimeType} not supported.`);
}
}
}
} catch (error) {
log(error.message);
}
}
Ergebnis
Kopieren Sie etwas Text oder das Schmetterlingsbild (JPG) unten (um Bilder zu kopieren, klicken Sie mit der rechten Maustaste auf sie und wählen Sie "Bild kopieren" aus dem Kontextmenü). Wählen Sie den angegebenen Rahmen unten aus, um diese Informationen aus der Zwischenablage in den Rahmen einzufügen.
Hinweise:
- Auch wenn das Schmetterlingsbild eine JPG-Datei ist, wird es, wenn es aus der Zwischenablage gelesen wird, als PNG gespeichert.
- Falls erforderlich, müssen Sie die Erlaubnis erteilen, um das Bild einzufügen.
- Dies funktioniert möglicherweise nicht in Chromium-Browsern, da dem Beispielrahmen nicht die Permissions-Policy
clipboard-read
undclipboard-write
Berechtigungen gewährt werden (erforderlich für Chromium-Browser).
Lesen von unbereinigtem HTML aus der Zwischenablage
Dieses Beispiel verwendet den formats
Parameter, um HTML-Daten aus der Zwischenablage zu lesen und den Code in seiner ursprünglichen Form, ohne dass der Browser ihn vorher bereinigt, zu erhalten.
HTML
<textarea id="source" rows="5">
<style>h1 {color: red;} p {color: blue;}</style>
<h1>Hello world!</h1>
<p>This is a test.</p>
<script>alert('Hello world!');</script>
</textarea>
<button id="copy">Copy HTML</button>
<button id="paste_normal">Paste HTML</button>
<button id="paste_unsanitized">Paste unsanitized HTML</button>
<textarea id="destination" rows="5"></textarea>
CSS
body {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 5px;
}
textarea {
grid-column: 1 / span 3;
}
JavaScript
const copyButton = document.getElementById("copy");
const pasteButton = document.getElementById("paste_normal");
const pasteUnsanitizedButton = document.getElementById("paste_unsanitized");
const sourceTextarea = document.getElementById("source");
const destinationTextarea = document.getElementById("destination");
copyButton.addEventListener("click", async () => {
const text = sourceTextarea.value;
const type = "text/html";
const blob = new Blob([text], { type });
const data = [new ClipboardItem({ [type]: blob })];
try {
await navigator.clipboard.write(data);
} catch (error) {
destinationTextarea.value = `Clipboard write failed: ${error}`;
}
});
async function getHTMLFromClipboardContents(clipboardContents) {
for (const item of clipboardContents) {
if (item.types.includes("text/html")) {
const blob = await item.getType("text/html");
const blobText = await blob.text();
return blobText;
}
}
return null;
}
pasteButton.addEventListener("click", async () => {
try {
const clipboardContents = await navigator.clipboard.read();
const html = await getHTMLFromClipboardContents(clipboardContents);
destinationTextarea.value =
html || "Could not find HTML data in the clipboard.";
} catch (error) {
destinationTextarea.value = `Clipboard read failed: ${error}`;
}
});
pasteUnsanitizedButton.addEventListener("click", async () => {
try {
const clipboardContents = await navigator.clipboard.read({
unsanitized: ["text/html"],
});
const html = await getHTMLFromClipboardContents(clipboardContents);
destinationTextarea.value =
html || "Could not find HTML data in the clipboard.";
} catch (error) {
destinationTextarea.value = `Clipboard read failed: ${error}`;
}
});
Ergebnis
Klicken Sie zuerst auf die Schaltfläche "HTML kopieren", um den HTML-Code aus dem ersten Textbereich in die Zwischenablage zu schreiben. Klicken Sie dann entweder auf die Schaltfläche "HTML einfügen" oder auf die Schaltfläche "Unbereinigtes HTML einfügen", um den bereinigten oder unbereinigten HTML-Code in den zweiten Textbereich einzufügen.
Spezifikationen
Specification |
---|
Clipboard API and events # dom-clipboard-read |
Browser-Kompatibilität
Siehe auch
- Clipboard API
- Entsperren des Zugriffs auf die Zwischenablage auf web.dev
- Unbereinigtes HTML in der Async Clipboard API auf developer.chrome.com
Clipboard.readText()
Clipboard.writeText()
Clipboard.write()