如何解决火狐在用offsetHeight获取div的高度时为0
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何解决火狐在用offsetHeight获取div的高度时为0,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1889字,纯文字阅读大概需要3分钟。
内容图文
![如何解决火狐在用offsetHeight获取div的高度时为0](/upload/InfoBanner/zyjiaocheng/412/a1168b12646d4a86907178a787176719.jpg)
火狐在需要获取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='javascript'> window.attachEvent( "onload", function(){ _resizeScroll2();} ); window.onresize=function(){winresize();}; function _resizeScroll2(){ var html1 = '<p id="pcj" style="margin-top:15px;font-size:10px;width:400px;">' + '<p style="float:left;width:50px;">测试</p>' + '<p style="float:left;width:320px;">danielinbiti</p>' + '</p>' + '<p id="pcj2" style="margin-top:15px;font-size:10px;width:400px;">' + '<p style="width:320px;">danielinbiti</p>' + '</p>' document.getElementById('outer').innerHTML=html1; document.getElementById('pcj2').style.display='none'; alert(document.getElementById('pcj2').offsetHeight); } </script> </head> <body> <p id='outer'></p> </body> </html>
如果获取pcj的高度,那么在onload中获取到的是0。因为pcj下有float方式布局的。
这时如果p简单,可以借助隐藏层,比如这里的pcj2,把float去掉后,获取到的高度和pcj一样高。
这里有一个关键点就是float布局在ie是没问题,但是对于火狐它取到就为0了
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
关于HTML5中video标签浏览器兼容性增强的方案分享
以上就是如何解决火狐在用offsetHeight获取div的高度时为0的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的如何解决火狐在用offsetHeight获取div的高度时为0全部内容,希望文章能够帮你解决如何解决火狐在用offsetHeight获取div的高度时为0所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。