ここに似た質問があります: Javascript ループ内のイベント ハンドラー - クロージャーが必要ですか? しかし、私はjQueryを使用しており、指定されたソリューションは、クリックではなくバインドされたときにイベントを発生させるようです。
これが私のコードです:
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);
}
}
}
私は成功せずにいくつかの異なる方法を試しました...
元の問題は、適切な画像を選択するためにパラメーターではなくループ カウンターを使用していたため、_this.Indicator.TrueImage が常に最後の値になることでした。