Heim > Web-Frontend > js-Tutorial > Wie kann ich „async/await' mit „Array.map' verwenden, um asynchrone Vorgänge abzuwickeln?

Wie kann ich „async/await' mit „Array.map' verwenden, um asynchrone Vorgänge abzuwickeln?

Barbara Streisand
Freigeben: 2024-12-15 17:36:12
Original
782 Leute haben es durchsucht

How Can I Use `async/await` with `Array.map` to Handle Asynchronous Operations?

Async-Await mit Array.map arbeiten lassen

Array.map ist eine leistungsstarke Methode zum Transformieren jedes Elements in einem Array. Die Verwendung mit asynchronen Vorgängen kann jedoch zu Herausforderungen führen.

Im bereitgestellten Codeausschnitt tritt der Fehler auf, weil die Ausgabe von „map“ eine Reihe von Versprechen und kein Versprechen ist. wait erwartet ein Versprechen und gibt den aufgelösten Wert zurück, aber bei einem Array gibt es das Array selbst zurück.

Um dieses Problem zu lösen, kann Promise.all verwendet werden, um das Array von Versprechen in ein einzelnes Versprechen umzuwandeln. Promise.all wartet darauf, dass alle Versprechen im Array aufgelöst werden, bevor das einzelne äußere Versprechen aufgelöst wird.

Der korrigierte Code:

var arr = [1,2,3,4,5];

var results: number[] = await Promise.all(arr.map(async (item): Promise<number> => {
    await callAsynchronousOperation(item);
    return item + 1;
}));
Nach dem Login kopieren

Diese Änderung stellt sicher, dass die Ausgabe von Array.map konvertiert wird in ein einziges Versprechen umwandeln, wodurch das kombinierte Ergebnis korrekt als Zahlenarray aufgelöst werden kann.

Das obige ist der detaillierte Inhalt vonWie kann ich „async/await' mit „Array.map' verwenden, um asynchrone Vorgänge abzuwickeln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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