ホームページ >ウェブフロントエンド >jsチュートリアル >続行する前に複数の JavaScript Promise が終了するまで待つにはどうすればよいですか?

続行する前に複数の JavaScript Promise が終了するまで待つにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-19 00:16:09379ブラウズ

How Can I Wait for Multiple JavaScript Promises to Finish Before Continuing?

JavaScript で複数の非同期タスクが完了するのを待機しています

問題:

一連の非同期タスクがあります (promise) )、すべてのコードが完了した場合にのみコード ブロックを実行する必要があります。

解決策:

Promise.all を使用して、すべての Promise を 1 つの配列に収集し、その解決を待つか、拒否。

実装:

const promises = [];

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

Promise.all(promises)
  .then(() => {
    for (let i = 0; i < 5; i++) {
      doSomeStuffOnlyWhenTheAsyncStuffIsFinish();
    }
  })
  .catch((e) => {
    // Handle errors here
  });

改訂された doSomeAsyncStuff 関数:

function doSomeAsyncStuff() {
  return new Promise((resolve, reject) => {
    const editor = generateCKEditor();
    editor.on('instanceReady', (evt) => {
      doSomeStuff();
      resolve(true);
    })
  });
}

例:

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 here
    });
}

test();

以上が続行する前に複数の JavaScript Promise が終了するまで待つにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。