Heim > Web-Frontend > js-Tutorial > Wie kann ich warten, bis alle Versprechen erfüllt sind, auch wenn einige scheitern?

Wie kann ich warten, bis alle Versprechen erfüllt sind, auch wenn einige scheitern?

Mary-Kate Olsen
Freigeben: 2025-01-03 11:08:39
Original
226 Leute haben es durchsucht

How Can I Wait for All Promises to Settle, Even if Some Fail?

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}
});
Nach dem Login kopieren

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);
});
Nach dem Login kopieren

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");
});
Nach dem Login kopieren

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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage