手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >offsetHeight在OnLoad中获取为0的现象
offsetHeight在OnLoad中获取为0的现象
摘要:在使用IE中,特别在目前div+css的方式,往往不定义div的高度,这是在添加div内容后,需要获取div的高度时,往往需要用到offse...

在使用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.onresize=function(){winresize();};

function _resizeScroll2(){

var html1 = '<div id="divcj">'

+ '<div>测试</div>'

+ '<div>danielinbiti</div>'

+ '</div>'

+ '<div id="divcj2">'

+ '<div>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一样高。

【offsetHeight在OnLoad中获取为0的现象】相关文章:

繁简字转换功能

黑色风格的JS日历代码,左右箭头翻页年、月

javascript判断并获取注册表中可信任站点的方法

JavaScript使用addEventListener添加事件监听用法实例

三种AngularJS中获取数据源的方式

Node.js开发者必须了解的4个JS要点

JavaScript容易犯错的九个陷阱

获取阴历(农历)和当前日期的js代码

jQuery获取上传文件的名称的正则表达式

在HTML中插入JavaScript代码的示例

精品推荐
分类导航