Element: paste Event

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

Das paste-Ereignis der Clipboard API wird ausgelöst, wenn der Benutzer über die Benutzeroberfläche des Browsers eine "Einfügen"-Aktion initiiert hat.

Wenn der Cursor sich in einem editierbaren Kontext befindet (zum Beispiel in einem <textarea> oder einem Element mit dem Attribut contenteditable, das auf true gesetzt ist), dann ist die Standardaktion, den Inhalt der Zwischenablage an der Cursorposition in das Dokument einzufügen.

Ein Handler für dieses Ereignis kann auf den Inhalt der Zwischenablage zugreifen, indem er getData() auf der clipboardData-Eigenschaft des Ereignisses aufruft.

Um das Standardverhalten zu überschreiben (zum Beispiel, um andere Daten oder eine Transformation des Zwischenablageinhalts einzufügen), muss ein Ereignishandler die Standardaktion mit event.preventDefault() abbrechen und dann die gewünschten Daten manuell einfügen.

Es ist möglich, ein synthetisches paste-Ereignis zu erstellen und auszulösen, allerdings wird dies die Inhalte des Dokuments nicht beeinflussen.

Dieses Ereignis blubbert den DOM-Baum nach oben, schließlich bis zu Document und Window, es ist abbrechbar und ist komponiert.

Syntax

Verwenden Sie den Ereignisnamen in Methoden wie addEventListener(), oder setzen Sie eine Ereignis-Handler-Eigenschaft.

js
addEventListener("paste", (event) => { })

onpaste = (event) => { }

Ereignistyp

Beispiele

Live-Beispiel

HTML

html
<div class="source" contenteditable="true">Copy text from this box.</div>
<div class="target" contenteditable="true">And paste it into this one.</div>

JavaScript

js
const target = document.querySelector("div.target");

target.addEventListener("paste", (event) => {
  event.preventDefault();

  let paste = (event.clipboardData || window.clipboardData).getData("text");
  paste = paste.toUpperCase();
  const selection = window.getSelection();
  if (!selection.rangeCount) return;
  selection.deleteFromDocument();
  selection.getRangeAt(0).insertNode(document.createTextNode(paste));
  selection.collapseToEnd();
});

Ergebnis

Spezifikationen

Specification
Clipboard API and events
# clipboard-event-paste
HTML
# handler-onpaste

Browser-Kompatibilität

Siehe auch