WorkerGlobalScope: reportError() Methode
Hinweis: Diese Funktion ist nur in Web Workers verfügbar.
Die reportError() Methode des WorkerGlobalScope Interface kann verwendet werden, um Fehler an die Konsole oder die Ereignishandler globaler Bereiche zu melden und dabei eine nicht abgefangene JavaScript-Ausnahme zu simulieren.
Dieses Feature ist in erster Linie für benutzerdefinierte Event-Dispatching- oder Callback-Manipulations-Bibliotheken vorgesehen. Bibliotheken können dieses Feature nutzen, um Fehler im Callback-Code abzufangen und auf den obersten Ebenen erneut auszulösen. Dies stellt sicher, dass eine Ausnahme in einem Callback andere nicht daran hindert, behandelt zu werden, während gleichzeitig sichergestellt wird, dass Stack-Trace-Informationen für das Debugging auf oberster Ebene weiterhin leicht verfügbar sind.
Syntax
reportError(throwable)
Parameter
Rückgabewert
Keiner (undefined).
Ausnahmen
TypeError-
Die Methode wird ohne ein Fehlerargument aufgerufen.
Beispiele
Feature-Test für die Methode mit:
if (typeof self.reportError === "function") {
// function is defined
}
Der folgende Code zeigt, wie Sie einen Fehler erstellen und melden können und wie er entweder mit der onerror-Ereignishandler-Eigenschaft oder durch Hinzufügen eines Listeners für das error-Ereignis abgefangen werden kann.
Beachten Sie, dass der Handler, der onerror zugewiesen ist, true zurückgeben muss, um zu verhindern, dass das Ereignis weiter propagiert wird.
const newError = new Error("Some error message", "someFile.js", 11);
self.reportError(newError);
self.onerror = (message, source, lineno, colno, error) => {
console.error(`message: ${error.message}, lineno: ${lineno}`);
return true;
};
self.addEventListener("error", (error) => {
console.error(error.filename);
});
// Output
// > "message:Some error message, lineno: 11"
// > "someFile.js"
Spezifikationen
| Specification |
|---|
| HTML> # runtime-script-errors> |
Browser-Kompatibilität
Loading…
Siehe auch
WorkerGlobalScopeWindow.reportError()errorEreigniserrorEreigniserrorEreignis