inline-block属性还是非常有用的,但是在IE6 7下还是有那么点问题,现总结一下
在IE6 7下实际上对行内元素起作用但对块级元素就失去了它的作用,上代码
<div style="display:inline-block;border:1px solid red;width:100px;height:100px;">div1</div> <div style="display:inline-block;border:1px solid blue;width:100px;height:100px;">div2</div>
IE6 7未起到效果
data:image/s3,"s3://crabby-images/ef344/ef344ce167f0e7559d730275d01565618da6c7f3" alt=""
firefox chrome下正常显示
data:image/s3,"s3://crabby-images/c8a99/c8a99c6190639a95f6c873e21063a1ea858f9c67" alt=""
而对于行内元素IE6 7下可以实现inline-block
data:image/s3,"s3://crabby-images/8fd39/8fd39ba84ed93f4a8d55dbc1ab3d16e048eee147" alt=""
如果想在IE6 7下让块级元素也显示inline-block需要用到一下hack技术
<div style="display:inline-block;*display:inline;*zoom:1;border:1px solid red;width:100px;height:100px;">div1</div> <div style="display:inline-block;*display:inline;*zoom:1;border:1px solid blue;width:100px;height:100px;">div2</div>
data:image/s3,"s3://crabby-images/17848/1784829da217ebc4075bca6e48ccb477efc0e335" alt=""
zoom:1 是为了触发IE6 7 下的hasLayout属性,主要用于盒子模型解析的时候,这样就可以设置他的宽度和高度了。
关于float,主要以前不理解在元素浮动之后元素的显示方式即display方式,当元素浮动之后元素的display属性就变为类似于inline-block,所以在行内元素浮动之后可以设置他的高度,宽度
<span style="float:left;border:1px solid red;width:100px;height:100px;">span1</span> <span style="float:left;border:1px solid blue;width:100px;height:100px;">span2</span>
data:image/s3,"s3://crabby-images/9a646/9a646b6e48fa2eda470ffcd42d3e8bfa79626793" alt=""