Heim >Web-Frontend >js-Tutorial >Wie kann Promise.all() mehrere asynchrone Aufgaben effizient verarbeiten, bevor mit nachfolgenden Vorgängen fortgefahren wird?

Wie kann Promise.all() mehrere asynchrone Aufgaben effizient verarbeiten, bevor mit nachfolgenden Vorgängen fortgefahren wird?

Patricia Arquette
Patricia ArquetteOriginal
2024-12-15 19:19:15841Durchsuche

How Can Promise.all() Efficiently Handle Multiple Asynchronous Tasks Before Proceeding to Subsequent Operations?

Asynchrones Arbeiten mit mehreren Versprechen

Dieser Artikel befasst sich mit den Herausforderungen bei der Ausführung mehrerer asynchroner Aufgaben innerhalb von Schleifen und der Notwendigkeit, deren Abschluss sicherzustellen bevor Sie mit nachfolgenden Aufgaben fortfahren.

Problem: Umgang mit asynchronen Aufgaben in Schleifen

Stellen Sie sich ein Szenario vor, in dem eine Schleife eine Reihe von Aufgaben durchläuft, die jeweils asynchron ausgeführt werden. Nach der Schleife folgt eine weitere Schleife, die auf dem Abschluss der Aufgaben der ersten Schleife basiert. Wie können wir diese Koordination effizient erreichen?

Promises und Promise.all()

Promises bieten eine elegante Lösung für dieses Problem. Indem wir ein Versprechen von doSomeAsyncStuff() zurückgeben, können wir die asynchronen Vorgänge verwalten.

Promise.all() ist eine leistungsstarke Methode, die eine Reihe von Versprechen akzeptiert und ein einzelnes Versprechen zurückgibt. Dieses einzelne Versprechen wird nur aufgelöst, wenn alle Eingabezusagen aufgelöst oder eines davon abgelehnt wird.

Implementierung

Um unser Ziel zu erreichen, können wir Promise.all() wie folgt nutzen:

const promises = [];

for (let i = 0; i < 5; i++) {
  promises.push(doSomeAsyncStuff());
}

Promise.all(promises)
  .then(() => {
    // Execute tasks that require all async tasks to finish
  })
  .catch((e) => {
    // Handle errors
  });

In dieser Implementierung sammeln wir alle Versprechen in einem Array und übergeben es an Promise.all(). Nach der Lösung (oder Ablehnung) fahren wir mit den Aufgaben der zweiten Schleife fort.

Zusätzliche Überlegungen

  • Für mehr Klarheit verwenden Sie const oder let anstelle von var.
  • Erwägen Sie die Behandlung von Fehlern mithilfe der Catch-Methode.
  • Weiteres Verständnis finden Sie in der MDN-Dokumentation zu Versprechen und in meinem Buch „JavaScript: „The New Toys“ (Links in meinem Profil).

Beispiel

Das folgende Beispiel zeigt die Verwendung von Promise.all(), um auf den Abschluss mehrerer asynchroner Aufgaben zu warten:

function doSomethingAsync(value) {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log("Resolving " + value);
      resolve(value);
    }, Math.floor(Math.random() * 1000));
  });
}

function test() {
  const promises = [];

  for (let i = 0; i < 5; i++) {
    promises.push(doSomethingAsync(i));
  }

  Promise.all(promises)
    .then((results) => {
      console.log("All done", results);
    })
    .catch((e) => {
      // Handle errors
    });
}

test();

Das obige ist der detaillierte Inhalt vonWie kann Promise.all() mehrere asynchrone Aufgaben effizient verarbeiten, bevor mit nachfolgenden Vorgängen fortgefahren wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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