Was halten Sie von Promise.allSettled()?
AllSettled sieht für mich wie eine Lösung auf der Suche nach einem Problem aus. Das Problem besteht darin, dass Entwickler Fehler nicht behandeln.
Promise.allSettled() hat ein sehr einfaches Design:
const allSettled = (promises) => Promise.all(promises.map(entry => entry .then((value) => ({ status: 'fulfilled', value })) .catch((reason) => ({ status: 'rejected', reason })) ));
Es stellt ein „konsistentes“ Ergebnisobjekt bereit – nun, der Status ist konsistent, sodass Sie .filter() sauberer verwenden können als Object.hasOwn(), aber Wert und Grund sind absichtlich unterschiedlich, sodass Sie sie nicht verwechseln können.
Meistens fügt allSettled jedem Versprechen für Sie eine .catch() hinzu.
Aber hier ist mein Knackpunkt: Wenn Sie eine Gruppe von Diensten parallel aufrufen und wissen, dass einer oder mehrere ausfallen können, es aber nicht wirklich wichtig ist ... warum schreiben Sie dafür keine Fehlerbehandlung?
const getFlakyService = (payload) => fetch(flakyUrl, payload); Promise.allSettled([ getFlakyService({ type: 'reptiles' }), getFlakyService({ type: 'mammals' }), getFlakyService({ type: 'birds' }), getFlakyService({ type: 'amphibians' }), ]).then((outcomes) => outcomes .filter(({ status }) => status === 'fulfilled')) });
Wie viel Aufwand sparen wir im Vergleich dazu:
const getFlakyService = (payload) => fetch(flakyUrl, payload) // We don't really care about the failures .catch(() => undefined); Promise.all([ getFlakyService({ type: 'reptiles' }), getFlakyService({ type: 'mammals' }), getFlakyService({ type: 'birds' }), getFlakyService({ type: 'amphibians' }), ]).then((data) => { /* ... */ });
Wenn es Ihnen wichtig ist, welche Anrufe fehlschlagen, benötigen Sie wahrscheinlich die zur Nachverfolgung zugänglichen Anforderungsinformationen, deren Verfügbarkeit im Grund nicht garantiert ist. Promise.allSettled ist in diesem Fall noch weniger hilfreich und es ist sinnvoller, eine eigene Fehlerbehandlung zu schreiben.
const getFlakyService = (payload) => fetch(flakyUrl, payload) // Send the failures details to a tracking/logging layer .catch((error) => trackRequestError(flakyUrl, payload, error); Promise.all([ getFlakyService({ type: 'reptiles' }), getFlakyService({ type: 'mammals' }), getFlakyService({ type: 'birds' }), getFlakyService({ type: 'amphibians' }), ]).then((data) => { /* ... */ });
Ich gebe zu, dass die Standardisierung des „Ergebnisses“ praktisch sein könnte. Mit allSettled können Sie die Fehler zählen, sobald sie alle abgeschlossen sind. Aber das gilt auch für die benutzerdefinierte Fehlerbehandlung.
Ich werde Promise.all() in naher Zukunft weiterhin verwenden, aber ich bin daran interessiert, mehr über Ihre Anwendungsfälle für Promise.allSettled() zu erfahren und warum Sie es bevorzugen.
Das obige ist der detaillierte Inhalt vonBrauchen wir Promise.allSettled()?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!