offsetHeight在OnLoad中为0的现象

27 篇文章 0 订阅
18 篇文章 0 订阅

在使用IE中,特别在目前div+css的方式,往往不定义div的高度,这是在添加div内容后,需要获取div的高度时,往往需要用到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='javascript'>
		window.attachEvent( "onload", function(){ _resizeScroll2();} );
		window.οnresize=function(){winresize();};
		function _resizeScroll2(){
			 var html1 = '<div id="divcj" style="margin-top:15px;font-size:10px;width:400px;">'
		     + '<div style="float:left;width:50px;">测试</div>'
		   	 + '<div style="float:left;width:320px;">danielinbiti</div>'
  		   + '</div>'
  		   + '<div id="divcj2" style="margin-top:15px;font-size:10px;width:400px;">'
		   	 + '<div style="width:320px;">danielinbiti</div>'
  		   + '</div>'
			 document.getElementById('outer').innerHTML=html1;
			 document.getElementById('divcj2').style.display='none';
			 alert(document.getElementById('divcj2').offsetHeight);
		}
  </script>
</head>
<body>
	<div id='outer'></div>
</body>
</html>

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

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值