Maison >interface Web >js tutoriel >Pourquoi les gestionnaires de clics basés sur des boucles en JavaScript affichent-ils parfois des valeurs inattendues ?

Pourquoi les gestionnaires de clics basés sur des boucles en JavaScript affichent-ils parfois des valeurs inattendues ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-27 04:53:16999parcourir

Why Do Loop-Based Click Handlers in JavaScript Sometimes Display Unexpected Values?

Gestion des événements de clic dans une boucle : comprendre les pièges de la fermeture

Lors de l'attribution de gestionnaires de clics à plusieurs éléments avec une boucle, il est essentiel d'en être conscient du mécanisme de fermeture de JavaScript. Une erreur courante consiste à créer des fermetures dans une boucle sans utiliser de fonctions de rappel. Cela peut conduire à un comportement inattendu.

Dans l'extrait de code fourni :

$(document).ready(function(){
  for(var i = 0; i < 20; i++) {
    $('#question' + i).click( function(){
      alert('you clicked ' + i);
    });
  }
});

Le comportement attendu est que cliquer sur #mydiv3 afficherait "vous avez cliqué sur 3". Cependant, le code utilise incorrectement la variable i, qui est une variable globale dans la boucle. Par conséquent, la variable i contient la valeur finale de 20, provoquant un message d'alerte incorrect.

La bonne façon d'attribuer des gestionnaires de clics dans une boucle consiste à utiliser des fonctions de rappel. Ces fonctions peuvent créer une nouvelle portée pour la variable i, garantissant que chaque itération de la boucle a sa propre instance de i.

function createCallback(i){
  return function(){
    alert('you clicked ' + i);
  }
}

$(document).ready(function(){
  for(var i = 0; i < 20; i++) {
    $('#question' + i).click(createCallback(i));
  }
});

Une autre solution moderne, si vous utilisez ES6, consiste à utiliser le mot-clé let pour créer une variable locale pour chaque itération de la boucle :

for(let i = 0; i < 20; i++) {
  $('#question' + i).click( function(){
    alert('you clicked ' + i);
  });
}

Cette approche est plus propre et plus facile à comprendre. Il garantit que chaque gestionnaire de clics possède sa propre variable i, éliminant ainsi les pièges de fermeture et garantissant un comportement correct lors de la gestion des événements de clic dans une boucle.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn