Heim >Web-Frontend >js-Tutorial >Wie kann ich warten, bis alle Versprechen erfüllt sind, auch wenn einige scheitern?
Warten auf alle Versprechen, unabhängig von Fehlern
In Szenarien, in denen Sie eine Reihe von Versprechen haben und Netzwerkanfragen stellen, bei denen es zu Fehlern kommen kann, können Sie Warten Sie möglicherweise lieber, bis alle Versprechen erfüllt sind, bevor Sie fortfahren, auch wenn einige fehlschlagen.
Die integrierte Die Promise.allSettled-Methode bietet eine unkomplizierte Lösung:
Promise.allSettled([promise]).then(([result]) => { // Reached regardless of outcome // {status: "fulfilled", value: 33} });
Vor der Einführung von Promise.allSettled konnten Sie eine Reflect-Funktion verwenden, um das gleiche Ergebnis zu erzielen:
const reflect = (p) => p.then( (v) => ({ v, status: "fulfilled" }), (e) => ({ e, status: "rejected" }) ); reflect(promise).then((v) => { console.log(v.status); });
Alternativ: Erweitern der Reflect-Funktion, um mit einer Reihe von Versprechen zu arbeiten:
function reflect(promises) { return Promise.all(promises.map((p) => { return p.then((v) => ({ v: v, status: "fulfilled" }), (e) => ({ e: e, status: "rejected" })); })); } reflect(promises).then((results) => { var success = results.filter((x) => x.status === "fulfilled"); });
Durch die Verwendung dieser Techniken können Sie Netzwerkausfälle elegant bewältigen und stellen Sie sicher, dass Ihr Code weiterhin wie beabsichtigt ausgeführt wird, unabhängig davon, ob einige Versprechen erfolgreich sind oder nicht.
Das obige ist der detaillierte Inhalt vonWie kann ich warten, bis alle Versprechen erfüllt sind, auch wenn einige scheitern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!