この記事は、JavaScript ループに関する関連知識を提供します。主に、js ループでの await の使用方法と結果の分析について説明します。興味のある友人は、ぜひ読んでみてください。すべての人に役立つことを願っています。ヘルプ。
序文
この質問はどのようにして生じたのでしょうか?ある日、非同期の知識について学習しているときに、次の質問に遭遇しました。Promise を使用して配列の値を毎秒出力します。
const arr = [1, 2, 3] arr.reduce((pre, cur) => { return pre.then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(cur)) }, 1000); }) }) }, Promise.resolve())
このコードは非常に理解しやすく、
Promise.resolve().then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(1)) }, 1000); }) }).then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(2)) }, 1000); }) }).then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(3)) }, 1000); }) })
と同等です。これを読んで、ループで値を出力するたびに 1 秒停止すれば解決するのではないかと思い、次のコードを思いつきました。
const arr = [1, 2, 3] const sleep = (ms) => { return new Promise((resolve, reject) => { setTimeout(() => { resolve() }, ms) }) } for (let i = 0; i < arr.length; i++) { console.log(arr[i]); await sleep(1000) }
印刷結果も一貫しています。予想通り、私はここで最初の質問をしました: await は async で使用する必要はありませんか?ここだけでどうやって使うことができるのでしょうか? (信じられない場合は、ブラウザのコンソールにコードを入力してみてください)
次に、for を forEach に変更しましたが、効果がまったく達成されていないことがわかりました。 forEach で失敗しますか?
arr.forEach(async item => { console.log(item); await sleep(1000) })
これら 2 つの質問から、答えを探して勉強してください。
for ループの await
#async/await を学習していたときに、await は async でのみ使用できるという文があったことを覚えています。実際、この文はそれは何の問題もありません。では、なぜ直接前に await を書くことができるのでしょうか? ブラウザのコンソールに直接書いているからです。エディタでコードを書くときは、非同期の<script> const arr = [1, 2, 3] const sleep = (ms) => { return new Promise((resolve, reject) => { setTimeout(() => { resolve() }, ms) }) } const logByOneSecond = async () => { for (let i = 0; i < arr.length; i++) { console.log(arr[i]); await sleep(1000) } } logByOneSecond() </script>
にすることができます。
const logByForof = async () => { for (const item of arr) { console.log(item); await sleep(1000) } } logByForof()
const logByWhile = async () => { let i = 0 while (i !== arr.length) { await sleep(1000) console.log(arr[i]); i++ } } logByWhile()
await in the forEach ループ
As at begin, in forEach には期待される効果はありません; まず第一に、結果が得られます: forEach の async と await は無効です。 私が見た説明は次のとおりです。while(index < arr.length){ callback(item, index) }
async ()=>{ await sleep(1000); } async ()=>{ await sleep(1000); } async ()=>{ await sleep(1000); }
概要
ループ内での async/await の使用を確認しました通常の for ループの場合、while、for-in、for-of などを含むすべての await はシリアルに呼び出され、安心して使用できますが、forEach、map、filter、reduce などのコールバックを伴う配列メソッドでは、 、などは副作用が多いのでawaitは使わない方が良いです。 [推奨学習:JavaScript 上級チュートリアル]
以上がJS ループで await を使用するとどのような「化学反応」が起こるかについて話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。