当单选按钮组被更改/单击时,我正在使用jQuery隐藏和显示元素。它在Firefox之类的浏览器中运行良好,但是在IE 6和IE 7中,仅当用户单击页面上的其他位置时,该操作才会发生。
详细地说,当您加载页面时,一切看起来都很好。在Firefox中,如果单击单选按钮,则会隐藏一个表行,而另一行会立即显示。但是,在IE 6和7中,单击单选按钮,直到单击页面上的任何位置,都不会发生任何事情。IE才会重新绘制页面,隐藏并显示相关元素。
这是我正在使用的jQuery:
$(document).ready(function () {
$(".hiddenOnLoad").hide();
$("#viewByOrg").change(function () {
$(".visibleOnLoad").show();
$(".hiddenOnLoad").hide();
});
$("#viewByProduct").change(function () {
$(".visibleOnLoad").hide();
$(".hiddenOnLoad").show();
});
});
这是XHTML会影响的部分。整个页面验证为XHTML 1.0 Strict。
<tr>
<td>View by:</td>
<td>
<p>
<input type="radio" name="viewBy" id="viewByOrg" value="organisation"
checked="checked" />Organisation</p>
<p>
<input type="radio" name="viewBy" id="viewByProduct" value="product" />Product</p>
</td>
</tr>
<tr class="visibleOnLoad">
<td>Organisation:</td>
<td>
<select name="organisation" id="organisation" multiple="multiple" size="10">
<option value="1">Option 1</option>
<option value="2">Option 2</option>
</select>
</td>
</tr>
<tr class="hiddenOnLoad">
<td>Product:</td>
<td>
<select name="product" id="product" multiple="multiple" size="10">
<option value="1">Option 1</option>
<option value="2">Option 2</option>
</select>
</td>
</tr>
如果有人对为什么发生这种情况以及如何解决有任何想法,将不胜感激!