javascript - js の落とし穴の質問: setTimeout() 関数の結果が実行後 5 6 秒になる理由は何ですか?
黄舟
黄舟 2017-05-19 10:47:29
0
3
787

setTimeout() 関数の結果が実行後 5 6 秒になるのはなぜですか?

リーリー

js クロージャを使用して問題を解決し、目的の 1、2、3、4、5 を取得しましたが、なぜ上記のコードに 6 が 5 つも表示されるのか理解できません。

リーリー
黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全員に返信(3)
PHPzhong

最初に理解する必要があるのは、JS のタスクメカニズムはキューメカニズムであるということです。

つまり、for ループを実行する代わりに、setTimeout タスクをキューの最後に置くだけです。つまり、setTimeout で実行されるコードは for ループが実行された後にのみ実行されるため、その時点の i の値は次のようになります。 for ループを満たさない値の場合は、setTimeout コードが実行されます。

個人的な意見ですので、間違っているところがあればご指摘ください

いいねを押す +0
Peter_Zhu

var は let に変更できます

var はグローバル定義であり、i はクロージャーを形成せず、log(i) は i 6 の最終値を出力します

let はブロックレベルのドメインです

リーリー
いいねを押す +0
为情所困

setTimeout には 2 つの特徴があります。this がコンテキストの this から分離されていることと、その呼び出しが非同期であることです。

これは [非同期] が原因で、for ループが最初に完了し、その後 setTimeout が実行されます。for ループは実行されるたびに最後に 6 になるため、当然 setTimeout してから i を呼び出します。 5 6

解決策 1:

リーリー

解決策 2:

リーリー

解決策 3:

リーリー
いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート