JavaScript イベント ハンドラーは、ループを使用して複数の要素に効果的に割り当てることができます。ただし、動的に生成された一連の要素に一意のクリック イベントを割り当てようとすると、ループが最後の要素にのみイベントを割り当てているように見えるため、課題が発生します。
問題の根本は、for ループによって作成されたクロージャにあります。すべてのハンドラーは同じ i 変数を共有し、反復ごとに増分されます。すべてのハンドラーが実行されると、実行時の i 変数はループ内の最後の要素の値を保持し、その結果、すべてのハンドラーは最後の値のみを表示します。
この問題を解決するには、ループ反復子 i をパラメーターとして、各要素のイベント ハンドラーを作成する別の関数に渡します。そうすることで、各ハンドラーはイテレーターの独自のコピーを取得し、クロージャーの問題を回避します。以下に例を示します。
function handleElement(i) { document.getElementById("b" + i).onclick = function () { alert(i); }; } // Create event handlers for each element for (i = 1; i < 11; i++) { handleElement(i); }
このソリューションでは、handleElement 関数がイベント ハンドラーの作成をカプセル化し、各ハンドラーが一意の値 i を持つ独自の囲まれたスコープを持つようにします。
上記の手法を使用すると、ループを通じて生成された複数の要素に固有のイベント ハンドラーを割り当てることができます。クロージャの概念を理解し、JavaScript のパラメータ受け渡し機能を活用することで、動的に生成されたコンポーネント上のイベントを効果的に処理できます。
以上がJavaScript でループを使用して固有のイベント ハンドラーを割り当てるときにクロージャの問題を回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。