CSS布局奇淫技巧之-宽度自适应
css 这个东西,说难不难,说容易也不容易。我觉得最重要的还是经验的积累,正所谓的不积硅步,无以至千里。这一系列文章讲述几种 css 特殊布局的实现,也当作为自己做个备忘吧。
首先讲的是三列布局,左右两列宽度固定,中间一列宽度自适应
这个很好实现,左右两列分别左浮动和右浮动并给一个固定宽度,中间不浮动,也不设定宽度。这样基本就可以了。但为了兼容 IE 还必须做些工作。
看下代码结构:
效果为:
中间列要不要设置 margin-left 和 margin-right ?
注意,中间那列需要把左右两个外边距分别设为左右两列的宽度,否则会有些问题。如下:
在谷歌、火狐等标准浏览器下是这样的(包括 IE8+):
而在 IE6、IE7 中是这样的(图是在 IE6 下截的)
我们可以看到中间那列子元素的 margin-left 或 margin-right 的起点是不一致的,在 IE6、IE7 中,即使不给中间列设定 margin-left 和 margin-right, 它的子元素的左右外边距的起点仍然是在左右两列宽的的基础上的,就像是有 margin-left 和 margin-right 一样。所以为了各浏览器保持一致,中间那列还是设一个 margin-left 和 margin-right 为好。
IE6 中的 3px 间隙 bug
在上图的 ie6 截图中,我们看到各列之间有一条 3px 的间隔,这是只有 IE6 才有的问题。
如果中间那列的 margin-left 和 margin-right 都为 0 的话,则只要把左列的 margin-right 设为 -3px, 右列的 margin-left 设为 -3px 就行了。
但如果把中间列的 margin-left 和 margin-right 分别为左右两列的宽度时(上面已经说了,这也是必须这样做的),即使把左列的 margin-right 设为 -3px, 右列的 margin-left 设为 -3px 也还是没有效果。这时候还得把中间列的 margin-left 设为左列宽度 -3px,margin-right 设为右列宽度 -3px 才行。如下:
最终的代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | <! DOCTYPE html> < html > < head > < meta charset="utf-8" /> < title >宽度自适应布局</ title > < style > body,div{ margin:0; padding:0;} div{ height:200px; color:#F00;} .left{ float:left; width:100px; background:#00f; _margin-right:-3px;} .right{ float:right; width:100px; background:#0f0; _margin-left:-3px;} .center{ background:#333; margin:0 100px; _margin:0 97px;} </ style > </ head > < body > < div class="left">我是left</ div > < div class="right">我是right</ div > < div class="center">我是center</ div > </ body > </ html > |
两列布局,一列宽度固定,另一列自适应布局也是这个道理的。