javascript在IE和FIREFOX的区别研究(一)

王朝html/css/js·作者佚名  2007-04-30
窄屏简体版  字體: |||超大  

最近发现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">

为了看的更清楚,写的几个字,并且放了一个大图片

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航