ホームページ > ウェブフロントエンド > jsチュートリアル > setTimeout を使用した For ループが予期しない値を出力するのはなぜですか?

setTimeout を使用した For ループが予期しない値を出力するのはなぜですか?

Patricia Arquette
リリース: 2024-12-29 07:46:15
オリジナル
929 人が閲覧しました

Why Does a For-Loop with setTimeout Print Unexpected Values?

setTimeout でラップされた For ループが予期しない値を出力する

このスクリプトでは、for ループが変数 i を 1 から 2 まで繰り返します。ループ内では、タイムアウト関数が 100 ミリ秒の遅延で設定され、次の値を警告します。 i 実行時。ただし、予期される動作は、スクリプトが 1 と 2 を連続して出力することですが、代わりに 3 が 2 回アラートされます。

予期しない動作は、i がループ全体で共有され、ループとして変更されるという事実に起因します。進歩します。タイムアウト関数が実行されるまでに、i はすでに 3 に達しており、両方のアラートにその値が表示されます。

この問題を解決し、値が連続して出力されるようにするには、タイムアウト関数ごとに i の個別のコピーを作成する必要があります。 。これは、i を引数として受け取り、その特定の値を使用してタイムアウトを設定する専用関数 doSetTimeout を定義することで実現できます。

doSetTimeout を使用して変更されたスクリプトは次のとおりです。

function doSetTimeout(i) {
  setTimeout(function() {
    alert(i);
  }, 100);
}

for (var i = 1; i <= 2; ++i)
  doSetTimeout(i);
ログイン後にコピー

この変更により、ループの各反復で doSetTimeout に渡される i の新しいコピーが作成され、各タイムアウトが正しい値で実行されるようになります。値。

以上がsetTimeout を使用した For ループが予期しない値を出力するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート