Heim > Web-Frontend > js-Tutorial > Wie serialisiere ich Versprechen in einer JavaScript ES6 For-Schleife?

Wie serialisiere ich Versprechen in einer JavaScript ES6 For-Schleife?

Linda Hamilton
Freigeben: 2024-11-27 19:44:19
Original
359 Leute haben es durchsucht

How to Serialize Promises in a JavaScript ES6 For Loop?

JavaScript ES6 Promise For-Loop-Serialisierung

Im angegebenen Code versuchen Sie, Versprechen sequentiell innerhalb einer for-Schleife auszuführen, stoßen jedoch auf ein Problem Die Schleife wird synchron ausgeführt, was zu einer unvorhersehbaren Ausgabe führt.

Verstehen des Problem:

Ein Versprechen kapselt einen asynchronen Vorgang, aber die synchrone Natur der Schleife löst alle Versprechen gleichzeitig aus und ignoriert die gewünschte Reihenfolge.

Promisifying setTimeout:

Um die sequentielle Ausführung zu erleichtern, können wir setTimeout versprechen, um ein Versprechen zu erhalten, das aufgelöst wird, wenn das Timer läuft ab:

const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
Nach dem Login kopieren

Lösungsoptionen:

Es gibt mehrere Möglichkeiten, dieses Problem zu lösen, indem Versprechen und asynchrone Programmiertechniken genutzt werden.

1. For-Schleife mit anfänglichem Versprechen:

Indem Sie mit einem sofort auflösenden Versprechen beginnen, können Sie nachfolgende Versprechen verketten, während die vorherigen aufgelöst werden:

for (let i = 0, p = Promise.resolve(); i < 10; i++) {
  p = p
    .then(() => delay(Math.random() * 1000))
    .then(() => console.log(i));
}
Nach dem Login kopieren

2. Array.reduce mit Initial Promise:

Mit Array.reduce können Sie eine Kette von Versprechen ähnlich dem for-Loop-Ansatz erstellen:

[...Array(10)]
  .reduce(
    (p, _, i) =>
      p.then(() => delay(Math.random() * 1000))
        .then(() => console.log(i)),
    Promise.resolve()
  );
Nach dem Login kopieren

3. Funktion als Promise Resolution Callback:

Sie können eine Funktion definieren, die sich selbst als Resolution Callback übergibt und so eine rekursive Promise Chain ermöglicht:

const loop = (i) => {
  delay(Math.random() * 1000)
    .then(() => console.log(i))
    .then(() => {
      if (i < 10) loop(i + 1);
    });
};
loop(0);
Nach dem Login kopieren

4. async/await-Syntax (ES2017):

ES2017 hat die async/await-Syntax eingeführt, um die asynchrone Codeverarbeitung zu vereinfachen:

const main = async () => {
  for (let i = 0; i < 10; i++) {
    await delay(Math.random() * 1000);
    console.log(i);
  }
};
main();
Nach dem Login kopieren

5. for waiting...of Syntax (ES2020):

ES2020 hat eine spezielle Syntax für die Iteration über asynchrone Iterables eingeführt:

(async () => {
  for await (const i of [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]) {
    await delay(Math.random() * 1000);
    console.log(i);
  }
})();
Nach dem Login kopieren

Durch die Verwendung dieser Techniken können Sie Versprechen nacheinander ausführen innerhalb einer Schleife, um die gewünschte Reihenfolge der Vorgänge sicherzustellen und unvorhersehbare Ausgaben zu vermeiden.

Das obige ist der detaillierte Inhalt vonWie serialisiere ich Versprechen in einer JavaScript ES6 For-Schleife?. 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