Heim >Web-Frontend >js-Tutorial >Wie führe ich eine Folge von Versprechen in JavaScript synchron aus?
In diesem Szenario haben wir ein Array von Versprechensobjekten, die in der genauen Reihenfolge aufgelöst werden müssen, die im Array angegeben ist. Wenn außerdem ein Element abgelehnt wird, sollte die gesamte Kette sofort abgelehnt werden, um weitere Versuche zur Auflösung nachfolgender Elemente zu verhindern.
Hier ist ein Beispiel, das die manuelle Iteration für die sequentielle Ausführung von Versprechen zeigt:
function processArray(array, fn) { var index = 0; function next() { if (index < array.length) { fn(array[index++]).then(next); } } return next(); }
Diese Funktion benötigt ein Array und eine Versprechen-zurückgebende Funktion fn als Argumente. Es durchläuft das Array, ruft fn für jedes Element auf und übergibt das Ergebnis an die nächste Iteration.
function processArray(array, fn) { return array.reduce((p, item) => { return p.then(() => { return fn(item).then((data) => { results.push(data); return results; }); }); }, Promise.resolve()); }
Dieser Ansatz verwendet die Methode Reduce() um eine Reihe von Ergebnissen zu sammeln. Jedes Element im Array wird nacheinander verarbeitet, wobei das von fn zurückgegebene Versprechen verwendet wird, um die Iteration voranzutreiben.
Die Bluebird Promise Library bietet praktische Methoden für die Handhabung asynchroner Vorgänge. einschließlich sequentieller Iteration.
Promise.mapSeries(arr, (item) => { // process each individual item here, return a promise return processItem(item); }).then((results) => { // process final results here }).catch((err) => { // process error here });
Die Promise.mapSeries()-Methode nimmt ein Array und eine Versprechen erzeugende Funktion und gibt ein Versprechen zurück, das in ein Array aufgelöster Ergebnisse aufgelöst wird.
Mit der ES7-Async/await-Syntax können sequentielle asynchrone Vorgänge prägnanter und lesbarer geschrieben werden:
async function processArray(array, fn) { let results = []; for (let i = 0; i < array.length; i++) { let r = await fn(array[i]); results.push(r); } return results; // will be resolved value of promise }
In diesem Beispiel iteriert die Funktion „processArray“ durch die Array, verwenden Sie „await“, um die Schleife anzuhalten, bis jedes von fn zurückgegebene Versprechen aufgelöst ist.
Der beste Ansatz zum Synchronisieren einer Folge von Versprechen hängt von Faktoren wie der Anzahl der Versprechen ab Elemente im Array, die Komplexität der Verarbeitungsfunktion fn und das gewünschte Fehlerbehandlungsverhalten. Für kleinere Arrays und einfache Verarbeitungsfunktionen kann eine manuelle Iteration oder die Verwendung von Promise.mapSeries() von Bluebird ausreichen. Für komplexere Szenarien ist die Verwendung von async/await oder einer benutzerdefinierten Lösung wie der in der endgültigen Antwort möglicherweise besser geeignet.
Das obige ist der detaillierte Inhalt vonWie führe ich eine Folge von Versprechen in JavaScript synchron aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!