html5中文学习网

您的位置: 首页 > 网页制作 > css教程 » 正文

火狐在用offsetHeight获取div的高度时为0的解决方法_浏览器兼容教程_CSS_网页制作

[ ] 已经帮助:人解决问题
点评:火狐在需要获取div的高度时,往往需要用到offsetHeight,有时会碰到offsetHeight获取到为0的现象,下面为大家介绍下比较实用的解决方法,感兴趣的朋友可参考下
火狐在需要获取div的高度时,往往需要用到offsetHeight,有时会碰到offsetHeight获取到为0的现象, 8MLHTML5中文学习网 - HTML5先行者学习网
在使用IE或者火狐中,特别在目前div+css的方式,往往不定义div的高度,这是在添加div内容后,需要获取div的高度时,往往需要用到offsetHeight。 8MLHTML5中文学习网 - HTML5先行者学习网
8MLHTML5中文学习网 - HTML5先行者学习网
在使用中,有时会碰到offsetHeight获取到为0的现象,但如果你用各种JS调试工具调试,又能在对象中看到值(如果直接指向offsetHeight是没值的,但如果是对象查看是有值的,在调试器中回车查看对象就已经刷新对象了,所以有值。) 8MLHTML5中文学习网 - HTML5先行者学习网
8MLHTML5中文学习网 - HTML5先行者学习网
比如下面片段 8MLHTML5中文学习网 - HTML5先行者学习网
代码如下: 8MLHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
8MLHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 8MLHTML5中文学习网 - HTML5先行者学习网
<html> 8MLHTML5中文学习网 - HTML5先行者学习网
<head> 8MLHTML5中文学习网 - HTML5先行者学习网
<script language='javascript'> 8MLHTML5中文学习网 - HTML5先行者学习网
window.attachEvent( "onload", function(){ _resizeScroll2();} ); 8MLHTML5中文学习网 - HTML5先行者学习网
window.onresize=function(){winresize();}; 8MLHTML5中文学习网 - HTML5先行者学习网
function _resizeScroll2(){ 8MLHTML5中文学习网 - HTML5先行者学习网
var html1 = '<div id="divcj" style="margin-top:15px;font-size:10px;width:400px;">' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '<div style="float:left;width:50px;">测试</div>' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '<div style="float:left;width:320px;">danielinbiti</div>' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '</div>' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '<div id="divcj2" style="margin-top:15px;font-size:10px;width:400px;">' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '<div style="width:320px;">danielinbiti</div>' 8MLHTML5中文学习网 - HTML5先行者学习网
+ '</div>' 8MLHTML5中文学习网 - HTML5先行者学习网
document.getElementById('outer').innerHTML=html1; 8MLHTML5中文学习网 - HTML5先行者学习网
document.getElementById('divcj2').style.display='none'; 8MLHTML5中文学习网 - HTML5先行者学习网
alert(document.getElementById('divcj2').offsetHeight); 8MLHTML5中文学习网 - HTML5先行者学习网
} 8MLHTML5中文学习网 - HTML5先行者学习网
</script> 8MLHTML5中文学习网 - HTML5先行者学习网
</head> 8MLHTML5中文学习网 - HTML5先行者学习网
<body> 8MLHTML5中文学习网 - HTML5先行者学习网
<div id='outer'></div> 8MLHTML5中文学习网 - HTML5先行者学习网
</body> 8MLHTML5中文学习网 - HTML5先行者学习网
</html> 8MLHTML5中文学习网 - HTML5先行者学习网
8MLHTML5中文学习网 - HTML5先行者学习网
如果获取divcj的高度,那么在onload中获取到的是0。因为divcj下有float方式布局的。 8MLHTML5中文学习网 - HTML5先行者学习网
8MLHTML5中文学习网 - HTML5先行者学习网
这时如果div简单,可以借助隐藏层,比如这里的divcj2,把float去掉后,获取到的高度和divcj一样高。 8MLHTML5中文学习网 - HTML5先行者学习网
8MLHTML5中文学习网 - HTML5先行者学习网
这里有一个关键点就是float布局在ie是没问题,但是对于火狐它取到就为0了
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助