7
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Promiseと配列

Last updated at Posted at 2018-08-10

次のような、配列の各要素に対して、何かの関数(syncFunc)を呼び出す処理をしているコードをPromise版のasyncFuncを使う形に置き換える時用のメモ

["foo", "bar", "baz"].forEach((e)=>{
  syncFunc(e);
});

以下のコードは全てasync function内にあるものと思ってください。

配列内の各要素に対する処理を並列に行なっても問題無い場合

await Promise.all(["foo", "bar", "baz"].map((e)=>{
  return asyncFunc(e);
}));

for ofを使うとこういう書き方もできます。

const tmp=[];
for(const e of ["foo", "bar", "baz"]){
  tmp.push(asyncConsoleLog(e));
}
await Promise.all(tmp);

promiseを格納する配列を別に用意する必要があるのがちょっと美しくないですが、関数に渡すデータが複数の配列に入っている時なんかは、このままforループを増やしていって、最後に一回Promise.allすれば良いので便利そうですね。

順次実行する(前の要素の処理が終わってから次の処理を行う)必要がある場合

await ["foo", "bar", "baz"].reduce((p,e)=>{
  return p.then(()=>{
    return asyncFunc(e);
  })
},Promise.resolve())

こちらも、for ofを使うと次のように書き換えられる。

for(const e of ["foo", "bar", "baz"]){
  await asyncConsoleLog(data);
}

こっちは圧倒的にfor ofの方が便利そうです。というか、そもそものreduce関数の使い方が分かり難いだけとも言えるかもしれませんが。

クリエイティブ・コモンズ・ライセンス
この記事は クリエイティブ・コモンズ 表示 4.0 国際 ライセンスの下に提供されています。


2019/3/27 reduce関数と書くべきところをmap関数と書いていたので訂正しました。

7
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?