hasLayout属性

hasLayout是IE特有的一个属性,很多的ie下的css bug都与其息息相关。

haslayout在ie8的标准模式下已经被废弃了,但是在ie7的兼容版本以及以下的版本是仍然存在的。

当一个元素的hasLayout属性值为true时,它负责对自己和可能的子孙元素进行尺寸计算和定位。虽然这意味着这个元素需要花更多的代价来维护自身和里面的内容,而不是依赖于祖先元素来完成这些工作。

很多情况下,我们把 hasLayout的状态改成true 就可以解决很大部分ie下显示的bug。

 

下列元素默认 hasLayout=true

<table> <td> <body> <img> <hr> <input> <select> <textarea> <button> <iframe> <embed> <object> <applet> <marquee>

 

hasLayout属性不能直接设定,你只能通过设定一些特定的css属性来触发并改变 hasLayout 状态。

列出可以触发hasLayout的一些CSS属性值。

 

display

启动haslayout的值:inline-block

取消hasLayout的值:其他值

--------------------------------------

width/height

启动hasLayout的值:除了auto以外的值

取消hasLayout的值:auto

---------------------------------------

position

启动hasLayout的值:absolute

取消hasLayout的值:static

----------------------------------------

float

启动hasLayout的值:left或right

取消hasLayout的值:none

---------------------------------------

zoom

启动hasLayout的值:有值

取消hasLayout的值:narmal或者空值

 

zoom是微软IE专有属性,可以触发hasLayout但不会影响页面的显示效果。

zoom: 1常用来除错,不过 ie 5 对这个属性不支持。"

 

 

hasLayout 引起的不兼容

无浮动盒子div模型内一个浮动div盒子,边框高度撑不开,其高度并不会自动计算

处理。

无浮动的div加上个zoom:1;来触发其hasLayout属性

给一个确定的高度值 height

添加浮动 float

添加定位 position

添加 display:inline-block

通常firefox等标准的遵守浏览器可以加上overflow: hidden;来解决,而IE则不行,需要触发其hasLayout属性才可以。

posted on 2014-12-11 22:32  bigdesign  阅读(162)  评论(0编辑  收藏  举报