CSS网页布局DIV水平居中的各类方法
1、单行垂直居中
若是一个容器中只有一行文字,对它实现居中相对比较简单,咱们只须要设置它的实际高度height和所在行的高度line-height相等便可。如:
imoker.cn(爱摩客)提供的代码片断:
1 div {
2 height:25px;
3 line-height:25px;
4 overflow:hidden;
5 }
这段代码很简单,后面使用overflow:hidden的设置是为了防止内容超出容器或者产生自动换行,这样就达不到垂直居中效果了。
imoker.cn(爱摩客)提供的代码片断
不过在Internet Explorer 6及如下版本中,这和方法不支持对图片设置垂直居中。
2、多行未知高度文字的垂直居中
若是一段内容,它的高度是可变的那么咱们就可使用上一节讲到的实现水平居中时使用到的最后一种方法,就是设定Padding,使上下的padding值相同便可。一样的,这也是一种“看起来”的垂直居中方式,它只不过是使文字把<div>彻底填充的一种方式而已。可使用相似下面的代码:
imoker.cn(爱摩客)提供的代码片断:
1 div {
2 padding:25px;
3 }
这种方法的优势就是它能够在任何浏览器上运行,而且代码很简单,只不过这种方法应用的前提就是容器的高度必须是可伸缩的。
3、多行文本固定高度的居中
1 div#wrap {
2 height:400px;
3 display:table;
4 }
5 div#content {
6 vertical-align:middle;
7 display:table-cell;
8 border:1px solid #FF0099;
9 background-color:#FFCCFF;
10 width:760px;
11 }
这个方法应该是很理想了,可是不幸的是Internet Explorer 6 并不能正确地理解display:table和display:table-cell,所以这种方法在Internet Explorer 6及如下的版本中是无效的。嗯,这让人很郁闷!不过咱们还其它的办法。
4、在Internet Explorer中的解决方案
在Internet Explorer 6及如下版本中,在高度的计算上存在着缺陷的。在Internet Explorer 6中对父元素进行定位后,若是再对子元素进行百分比计算时,计算的基础彷佛是有继承性的(若是定位的数值是绝对数值没有这个问题,可是使用百分比计算的基础将再也不是该元素的高度,而从父元素继承来的定位高度)。例如,咱们有下面这样一个(X)HTML代码段:
1 <div id="wrap">
2 <div id="subwrap">
3 <div id="content">
4 </div>
5 </div>
6 </div>
若是咱们对subwrap进行了绝对定位,那么content也会继承了这个属性,虽然它不会在页面中立刻显示出来,可是若是再对content进行相对定位的时候,你使用的100%分比将再也不是content原有的高度。例如,咱们设定了subwrap的position为40%,咱们若是想使content的上边缘和wrap重合的话就必须设置top:-80%;那么,若是咱们设定subwrap的top:50%的话,咱们必须使用100%才能使content回到原来的位置上去,可是若是咱们把content也设置50%呢?那么它就正好垂直居中了。因此咱们可使用这中方法来实现Internet Explorer 6中的垂直居中:
imoker.cn(爱摩客)提供的代码片断:
1 div#wrap {
2 border:1px solid #FF0099;
3
4 width:760px;
5 height:400px;
6 position:relative;
7 }
8 div#subwrap {
9 position:absolute;
10 border:1px solid #000;
11 top:50%;
12 }
13 div#content {
14 border:1px solid #000;
15 position:relative;
16 top:-50%;
17 }
固然,这段代码只能在Internet Exlporer 6等计算存在问题的浏览器中才会有做用。(不过我不解,我查阅了不少文章,不知道是由于出处相同仍是什么缘由,彷佛不少人都不肯意去解释Internet Exlporer 6中这个Bug的原理,我也只是了解了一点皮毛,还要再研究)
5、完美的解决方案
那么咱们综合上面两种方法就能够获得一个完美的解决方案,不过这要用到CSS hack的知识。对于若是使用CSS Hack来区分浏览器,你能够参考这篇“简单CSS hack:区分IE六、IE七、IE八、Firefox、Opera”:
1 div#wrap {
2 display:table;
3 border:1px solid #FF0099;
4 background-color:#FFCCFF;
5 width:760px;
6 height:400px;
7 _position:relative;
8 overflow:hidden;
9 }
10 div#subwrap {
11 vertical-align:middle;
12 display:table-cell;
13 _position:absolute;
14 _top:50%;
15 }
16 div#content {
17 _position:relative;
18 _top:-50%;
19 }
至此,一个完美的居中方案就产生了。