头闻号

北京京开玉峰建材供应站

综合性公司|室内涂料|室外涂料|防锈漆|防腐涂料

首页 > 新闻中心 > 科技常识:火狐在用offsetHeight获取div的高度时为0的解决方法
科技常识:火狐在用offsetHeight获取div的高度时为0的解决方法
发布时间:2023-02-01 09:52:55        浏览次数:4        返回列表

今天小编跟大家讲解下有关火狐在用offsetHeight获取div的高度时为0的解决方法 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关火狐在用offsetHeight获取div的高度时为0的解决方法 的相关资料,希望小伙伴们看了有所帮助。

火狐在需要获取div的高度时 往往需要用到offsetHeight 有时会碰到offsetHeight获取到为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.onresize=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一样高。 这里有一个关键点就是float布局在ie是没问题 但是对于火狐它取到就为0了

来源:爱蒂网