首页 >web前端 >css教程 >如何解决火狐在用offsetHeight获取div的高度时为0

如何解决火狐在用offsetHeight获取div的高度时为0

不言
不言原创
2018-06-21 16:33:502245浏览

火狐在需要获取p的高度时,往往需要用到offsetHeight,有时会碰到offsetHeight获取到为0的现象,下面为大家介绍下比较实用的解决方法,感兴趣的朋友可参考下

火狐在需要获取p的高度时,往往需要用到offsetHeight,有时会碰到offsetHeight获取到为0的现象, 

在使用IE或者火狐中,特别在目前p+css的方式,往往不定义p的高度,这是在添加p内容后,需要获取p的高度时,往往需要用到offsetHeight。 

在使用中,有时会碰到offsetHeight获取到为0的现象,但如果你用各种JS调试工具调试,又能在对象中看到值(如果直接指向offsetHeight是没值的,但如果是对象查看是有值的,在调试器中回车查看对象就已经刷新对象了,所以有值。) 

比如下面片段 

代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html> 
<head> 
<script language=&#39;javascript&#39;> 
window.attachEvent( "onload", function(){ _resizeScroll2();} ); 
window.onresize=function(){winresize();}; 
function _resizeScroll2(){ 
var html1 = &#39;<p id="pcj" style="margin-top:15px;font-size:10px;width:400px;">&#39; 
+ &#39;<p style="float:left;width:50px;">测试</p>&#39; 
+ &#39;<p style="float:left;width:320px;">danielinbiti</p>&#39; 
+ &#39;</p>&#39; 
+ &#39;<p id="pcj2" style="margin-top:15px;font-size:10px;width:400px;">&#39; 
+ &#39;<p style="width:320px;">danielinbiti</p>&#39; 
+ &#39;</p>&#39; 
document.getElementById(&#39;outer&#39;).innerHTML=html1; 
document.getElementById(&#39;pcj2&#39;).style.display=&#39;none&#39;; 
alert(document.getElementById(&#39;pcj2&#39;).offsetHeight); 
} 
</script> 
</head> 
<body> 
<p id=&#39;outer&#39;></p> 
</body> 
</html>

如果获取pcj的高度,那么在onload中获取到的是0。因为pcj下有float方式布局的。 

这时如果p简单,可以借助隐藏层,比如这里的pcj2,把float去掉后,获取到的高度和pcj一样高。 

这里有一个关键点就是float布局在ie是没问题,但是对于火狐它取到就为0了

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于HTML5中video标签浏览器兼容性增强的方案分享

以上是如何解决火狐在用offsetHeight获取div的高度时为0的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn