Window: unhandledrejection-Ereignis

Das unhandledrejection-Ereignis wird an den globalen Geltungsbereich eines Scripts gesendet, wenn ein JavaScript-Promise, das keinen Ablehnungs-Handler hat, abgelehnt wird; typischerweise ist dies das window, es kann aber auch ein Worker sein.

Dies ist nützlich zum Debuggen und um eine Notfall-Fehlerbehandlung für unerwartete Situationen bereitzustellen.

Syntax

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

js
addEventListener("unhandledrejection", (event) => {});
onunhandledrejection = (event) => {};

Ereignistyp

Ereigniseigenschaften

PromiseRejectionEvent.promise Schreibgeschützt

Das JavaScript-Promise, das abgelehnt wurde.

PromiseRejectionEvent.reason Schreibgeschützt

Ein Wert oder Object, der angibt, warum das Promise abgelehnt wurde, wie es an Promise.reject() übergeben wurde.

Ereignishandler-Aliase

Neben der Window-Schnittstelle ist die Ereignis-Handler-Eigenschaft onunhandledrejection auch bei den folgenden Zielen verfügbar:

Verwendungshinweise

Wenn das unhandledrejection-Ereignis weitergegeben wird, führt das letztendlich dazu, dass eine Fehlermeldung in der Konsole ausgegeben wird. Sie können dies verhindern, indem Sie preventDefault() auf dem PromiseRejectionEvent aufrufen; siehe Verhindern der Standardbehandlung unten für ein Beispiel.

Da dieses Ereignis Daten leaken kann, werden Promise-Ablehnungen, die von einem Cross-Origin-Skript stammen, dieses Ereignis nicht auslösen.

Beispiele

Grundlegende Fehlerprotokollierung

Dieses Beispiel protokolliert Informationen über die unbehandelte Promise-Ablehnung in der Konsole.

js
window.addEventListener("unhandledrejection", (event) => {
  console.warn(`UNHANDLED PROMISE REJECTION: ${event.reason}`);
});

Sie können auch die onunhandledrejection-Ereignis-Handler-Eigenschaft verwenden, um den Ereignis-Listener einzurichten:

js
window.onunhandledrejection = (event) => {
  console.warn(`UNHANDLED PROMISE REJECTION: ${event.reason}`);
};

Verhindern der Standardbehandlung

Viele Umgebungen (wie Node.js) melden unbehandelte Promise-Ablehnungen standardmäßig in der Konsole. Sie können dies verhindern, indem Sie einen Handler für unhandledrejection-Ereignisse hinzufügen, der—in Ergänzung zu allen anderen Aufgaben, die Sie ausführen möchten—preventDefault() aufruft, um das Ereignis abzubrechen und zu verhindern, dass es zur Protokollierungsroutine der Laufzeit aufsteigt. Dies funktioniert, weil unhandledrejection abbrechbar ist.

js
window.addEventListener("unhandledrejection", (event) => {
  // code for handling the unhandled rejection
  // …

  // Prevent the default handling (such as outputting the
  // error to the console)

  event.preventDefault();
});

Spezifikationen

Specification
HTML
# event-unhandledrejection
HTML
# handler-window-onunhandledrejection

Browser-Kompatibilität

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
unhandledrejection event

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
See implementation notes.

Siehe auch