En JavaScript, il est crucial d'être conscient de la portée et de la fermeture lors de la gestion des boucles for. Comme le démontre le scénario présenté, l'attribution de gestionnaires de clics dans la boucle à l'aide de la variable i sans encapsulation de fermeture appropriée entraîne un comportement inattendu.
Le problème sous-jacent vient du fait que la variable i déclarée dans la boucle est partagée entre itérations. Par conséquent, lorsque l'un des gestionnaires de clics est déclenché, la valeur de i augmente jusqu'à la valeur la plus élevée, ce qui entraîne des messages d'alerte incorrects.
Pour résoudre ce problème, une approche consiste à utiliser des fonctions de rappel. Ces fonctions encapsulent la variable i dans le cadre de leur fermeture, garantissant que chaque gestionnaire de clic fonctionne indépendamment :
function createCallback(i) { return function() { alert('you clicked ' + i); } } $(document).ready(function() { for (var i = 0; i < 20; i++) { $('#question' + i).click(createCallback(i)); } });
Alternativement, si vous utilisez ES6, le mot-clé let peut être utilisé pour créer une variable i de portée bloc dans chaque itération de la boucle :
for (let i = 0; i < 20; i++) { $('#question' + i).click(function() { alert('you clicked ' + i); }); }
En abordant les pièges de la fermeture, ces approches garantissent que chaque gestionnaire de clic affiche la valeur i correcte, représentant l'élément spécifique qui a été cliqué.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!