最近发现FF在隐藏的时候经常会出现隐藏掉了,但是位置还在,有些象IE下的visibility ,仔细看了下,发现有几种情况才会发生这种情况。这种情况在IE下不会出现,看下面的代码在FF中的运行吧,直接在运行的时候调用HB4函数,可以隐藏,完全没有问题。但是在不调用的时候,单击按钮来进行,首先第一个按钮,可完全隐藏table,第二个和第三个按钮则会出问题,不能隐藏掉tr和td,包括写table对象.rows或者row对象.cells方法都会出错,也就是说TR和TD在事件的驱动下有可能出现这种问题。
所以,为了避免这种情况发生,最好隐藏对象时不要对表格里的行和单元格来进行隐藏,而是在表格中设置div或者span容器,把要隐藏的对象放在这些容器中,对容器进行隐藏,这样就可以避免这种错误。
<table id="HBtable">
<tr id="HBtr" style="DISPLAY: block;height:200">
<td id="HBtd" style="background-color:red;DISPLAY: block;height:200">第一行<img src="http://community.csdn.net/logo/images/prj.210.67.gif" height="200">
</td>
</tr>
<tr style="background-color:green;DISPLAY: block">
<td>第二行
</td>
</tr>
</table>
<script language=javascript>
function HB1()
{
document.getElementById("HBtable").style.display="none"
alert("表格可以隐藏")
}
function HB2()
{
document.getElementById("HBtr").style.display="none"
alert("TR隐藏不行")
}
function HB3()
{
document.getElementById("HBtd").style.display="none"
alert("TD可以隐藏")
}
function HB4()
{
document.getElementById("HBtr").style.display="none"
alert("直接TR隐藏可以")
}
//HB4()//直接调用是可以隐藏的
</script>
<input name="button1" type="button" onclick="HB1()" value="隐藏TABLE">
<input name="button2" type="button" onclick="HB2()" value="隐藏TR">
<input name="button3" type="button" onclick="HB3()" value="隐藏TD">
为了看的更清楚,写的几个字,并且放了一个大图片