Promise.prototype.finally()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since October 2018.
Die finally()
-Methode von Promise
-Instanzen plant eine Funktion zur Ausführung, wenn das Promise abgeschlossen ist (entweder erfüllt oder abgelehnt). Sie gibt sofort ein weiteres Promise
-Objekt zurück und ermöglicht es Ihnen, Aufrufe anderer Promise-Methoden zu verketteln.
Dadurch können Sie Code-Duplikate in den then()
- und catch()
-Handlern eines Promises vermeiden.
Probieren Sie es aus
Syntax
promiseInstance.finally(onFinally)
Parameter
onFinally
-
Eine Funktion, die asynchron ausgeführt wird, wenn dieses Promise abgeschlossen wird. Der Rückgabewert wird ignoriert, es sei denn, es ist ein abgelehntes Promise. Die Funktion wird ohne Argumente aufgerufen.
Rückgabewert
Gibt sofort ein neues Promise
zurück. Dieses neue Promise ist immer ausstehend, wenn es zurückgegeben wird, unabhängig vom Status des aktuellen Promises. Wenn onFinally
einen Fehler auslöst oder ein abgelehntes Promise zurückgibt, wird das neue Promise mit diesem Wert abgelehnt. Andernfalls wird das neue Promise mit dem gleichen Status wie das aktuelle Promise abgeschlossen.
Beschreibung
Die finally()
-Methode kann nützlich sein, wenn Sie einige Verarbeitung oder Bereinigung durchführen möchten, sobald das Promise abgeschlossen ist, unabhängig von dessen Ergebnis.
Die finally()
-Methode ist der Verwendung von then(onFinally, onFinally)
sehr ähnlich. Es gibt jedoch einige Unterschiede:
- Bei der Erstellung einer Funktion in einer Zeile können Sie diese einmal übergeben, anstatt sie entweder zweimal zu deklarieren oder eine Variable dafür zu erstellen.
- Der
onFinally
Callback erhält kein Argument. Dieser Anwendungsfall ist genau dann, wenn Sie nicht interessiert sind am Grund für die Ablehnung oder dem Erfüllungswert und deshalb keine Notwendigkeit besteht, diesen anzugeben. - Ein
finally()
-Aufruf ist normalerweise transparent und spiegelt den letztendlichen Zustand des ursprünglichen Promises wider. Zum Beispiel:- Anders als
Promise.resolve(2).then(() => 77, () => {})
, welches ein Promise zurückgibt, das letztendlich mit dem Wert77
erfüllt wird, gibtPromise.resolve(2).finally(() => 77)
ein Promise zurück, das letztendlich mit dem Wert2
erfüllt wird. - Ähnlich, anders als
Promise.reject(3).then(() => {}, () => 88)
, welches ein Promise zurückgibt, das letztendlich mit dem Wert88
erfüllt wird, gibtPromise.reject(3).finally(() => 88)
ein Promise zurück, das letztendlich mit dem Grund3
abgelehnt wird.
- Anders als
Hinweis: Ein throw
(oder die Rückgabe eines abgelehnten Promises) im finally
Callback lehnt das zurückgegebene Promise weiterhin ab. Zum Beispiel lehnen sowohl Promise.reject(3).finally(() => { throw 99; })
als auch Promise.reject(3).finally(() => Promise.reject(99))
das zurückgegebene Promise mit dem Grund 99
ab.
Wie catch()
ruft finally()
intern die then
-Methode auf dem Objekt auf, bei dem sie aufgerufen wurde. Wenn onFinally
keine Funktion ist, wird then()
mit onFinally
als beide Argumente aufgerufen — was für Promise.prototype.then()
bedeutet, dass kein hilfreicher Handler angehängt wird. Andernfalls wird then()
mit zwei intern erstellten Funktionen aufgerufen, die sich wie folgt verhalten:
Warnung: Dies dient nur Demonstrationszwecken und ist kein Polyfill.
promise.then(
(value) => Promise.resolve(onFinally()).then(() => value),
(reason) =>
Promise.resolve(onFinally()).then(() => {
throw reason;
}),
);
Da finally()
then()
aufruft, unterstützt es das Subclassing. Außerdem beachten Sie den obigen Promise.resolve()
-Aufruf — in Wirklichkeit wird der Rückgabewert von onFinally()
unter Verwendung des gleichen Algorithmus wie Promise.resolve()
aufgelöst, aber der tatsächliche Konstruktor, der verwendet wird, um das aufgelöste Promise zu konstruieren, wird die Unterklasse sein. finally()
erhält diesen Konstruktor durch promise.constructor[Symbol.species]
.
Beispiele
Verwendung von finally()
let isLoading = true;
fetch(myRequest)
.then((response) => {
const contentType = response.headers.get("content-type");
if (contentType && contentType.includes("application/json")) {
return response.json();
}
throw new TypeError("Oops, we haven't got JSON!");
})
.then((json) => {
/* process your JSON further */
})
.catch((error) => {
console.error(error); // this line can also throw, e.g. when console = {}
})
.finally(() => {
isLoading = false;
});
Spezifikationen
Specification |
---|
ECMAScript Language Specification # sec-promise.prototype.finally |
Browser-Kompatibilität
BCD tables only load in the browser