所以我有一些像这样的html:
<div id="avatar_choices">
<label for="id_choice_0">
<input id="id_choice_0" type="radio" name="choice" value="7" />
<img src="someimage.jpg" />
</label>
<label for="id_choice_1">
<input id="id_choice_1" type="radio" name="choice" value="8" />
<img src="someimage2.jpg" />
</label>
</div>
还有一些脚本:
$('#avatar_choices input').hide();
$('#avatar_choices img').click(function(){
$('#avatar_choices img').css('border', '2px solid #efefef');
$(this).css('border', '2px solid #39c');
$(this).siblings('input').attr('checked', 'checked');
});
目标是允许用户单击图像选项,使所选的一个突出显示带有边框颜色。
这在 FF 中运行良好。出于某种原因,在 IE 中,一旦我单击一个图像,单击另一个图像,然后尝试单击第一个图像,边框不会改变(尽管它确实被选中)。
编辑:我的解决方案最终意外发生了一半。由于redsquare的回答,我将代码更改为:
$('#avatar_choices input').hide();
$('#avatar_choices img').click(function(){
$('#avatar_choices img').removeClass('selected');
$(this).addClass('selected');
$(this).siblings('input').attr('checked', 'checked');
});
在哪里:
#avatar_choices img.selected{border:2px solid #39c;}
去搞清楚。