J'ai une question similaire à celle-ci: Event handlers inside a Javascript loop - need a closure? mais j'utilise jQuery et la solution donnée semble déclencher l'événement quand il est lié plutôt que sur un clic.jQuery Fermetures, boucles et événements
Voici mon code:
for(var i in DisplayGlobals.Indicators)
{
var div = d.createElement("div");
div.style.width = "100%";
td.appendChild(div);
for(var j = 0;j<3;j++)
{
var test = j;
if(DisplayGlobals.Indicators[i][j].length > 0)
{
var img = d.createElement("img");
jQuery(img).attr({
src : DisplayGlobals.Indicators[i][j],
alt : i,
className: "IndicatorImage"
}).click(
function(indGroup,indValue){
jQuery(".IndicatorImage").removeClass("active");
_this.Indicator.TrueImage = DisplayGlobals.Indicators[indGroup][indValue];
_this.Indicator.FalseImage = DisplayGlobals.IndicatorsSpecial["BlankSmall"];
jQuery(this).addClass("active");
}(i,j)
);
div.appendChild(img);
}
}
}
J'ai essayé deux différentes façons sans succès ...
Le problème initial était que _this.Indicator.TrueImage était toujours la dernière valeur parce que je utilisait les compteurs de boucle plutôt que les paramètres pour choisir la bonne image.
Merci :) Sentez-vous une peu bête maintenant! –