CSS中实现DIV容器垂直居中方法揭秘

开发 前端
CSS布局中水平居中比垂直居中简单些,因为我们设计页面的时候往往水平宽度都是固定的,所以我们有必要总结一下在页面布局过程中实现垂直居中的方法。

本文向大家描述一下实现DIV容器垂直居中的方法,主要有单行垂直居中,多行未知高度文字的垂直居中,多行文本固定高度的居中等内容,相信本文介绍一定会让你有所收获。

DIV CSS教程:实现DIV容器垂直居中的方法

  其实CSS水平居中实现还是比较简单的,反而垂直居中有点麻烦,因为我们设计页面的时候往往水平宽度都是固定的。因此我们有必要总结一下在CSS页面布局过程中实现垂直居中的方法。

  在说到这个问题的时候,也许有人会问CSS中不是有vertical-align属性来设置垂直居中的吗?即使是某些浏览器不支持我只需做少许的CSSHack技术就可以啊!所以在这里我还要啰嗦两句,CSS中的确是有vertical-align属性,但是它只对(X)HTML元素中拥有valign特性的元素才生效,例如表格元素中的<td>、<th>、<caption>等,而像<DIV>、<span>这样的元素是没有valign特性的,因此使用vertical-align对它们不起作用。

一、单行垂直居中

如果一个容器中只有一行文字,对它实现居中相对比较简单,我们只需要设置它的实际高度height和所在行的高度line-height相等即可。如:

ExampleSourceCode 

DIV{  
height:25px;  
line-height:25px;  
overflow:hidden;  
}  
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

  这段代码很简,后面使用overflow:hidden的设置是为了防止内容超出容器或者产生自动换行,这样就达不到垂直居中效果了。

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>52CSS.com</title> 
<metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> 
<styletypestyletype="text/css"> 
 body{font-size:12px;font-family:tahoma;}  
 DIV{  
  height:25px;  
  line-height:25px;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
 }  
</style> 
</head> 
 
<body> 
<DIV>现在我们要使这段文字垂直居中显示!</DIV> 
</body> 
</html> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.

 [可先修改部分代码再运行查看效果]

  不过在InternetExplorer6及以下版本中,这和方法不支持对图片设置垂直居中。#p#

二、多行未知高度文字的垂直居中

  如果一段内容,它的高度是可变的那么我们就可以使用上一节讲到的实现水平居中时使用到的***一种方法,就是设定Padding,使上下的padding值相同即可。同样的,这也是一种“看起来”的垂直居中方式,它只不过是使文字把<DIV>完全填充的一种访求而已。可以使用类似下面的代码:

ExampleSourceCode

DIV{  
padding:25px;  
}  
  • 1.
  • 2.
  • 3.

  这种方法的优点就是它可以在任何浏览器上运行,并且代码很简单,只不过这种方法应用的前提就是容器的高度必须是可伸缩的。

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>52CSS.com</title> 
<metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> 
<styletypestyletype="text/css"> 
 body{font-size:12px;font-family:tahoma;}  
 DIV{  
  padding:25px;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
 }  
</style> 
</head> 
 
<body> 
<DIV><pre>现在我们要使这段文字垂直居中显示!  
 DIV{  
  padding:25px;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
 }  
</pre></DIV> 
</body> 
</html> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.

 [可先修改部分代码再运行查看效果]#p#

三、多行文本固定高度的居中

  在本文的一开始,我们已经说过CSS中的vertical-align属性只会对拥有valign特性的(X)HTML标签起作用,但是在CSS中还有一个display属性能够模拟<table>,所以我们可以使用这个属性来让<DIV>模拟<table>就可以使用vertical-align了。注意,display:table和display:table-cell的使用方法,前者必须设置在父元素上,后者必须设置在子元素上,因此我们要为需要定位的文本再增加一个<DIV>元素:

ExampleSourceCode 

DIV#wrap{  
height:400px;  
display:table;  
}  
DIV#content{  
vertical-align:middle;  
display:table-cell;  
border:1pxsolid#FF0099;  
background-color:#FFCCFF;  
width:760px;  
}  
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.

 SourceCodetoRun 

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>52CSS.com</title> 
<metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> 
<styletypestyletype="text/css"> 
 body{font-size:12px;font-family:tahoma;}  
 DIV#wrap{  
  height:400px;  
  display:table;  
 }  
 DIV#content{  
  vertical-align:middle;  
  display:table-cell;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
 }  
</style> 
</head> 
 
<body> 
<DIVidDIVid="wrap"> 
<DIVidDIVid="content"><pre>现在我们要使这段文字垂直居中显示!  
 DIV#wrap{  
  height:400px;  
  display:table;  
 }  
 DIV#content{  
  vertical-align:middle;  
  display:table-cell;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
 }  
</pre></DIV> 
</DIV> 
</body> 
</html> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.

[可先修改部分代码再运行查看效果]
  这个方法应该是很理想了,但是不幸的是InternetExplorer6并不能正确地理解display:table和display:table-cell,因此这种方法在InternetExplorer6及以下的版本中是无效的。嗯,这让人很郁闷!不过我们还其它的办法。#p#

四、在InternetExplorer中的解决方案

  在InternetExplorer6及以下版本中,在高度的计算上存在着缺陷的。在InternetExplorer6中对父元素进行定位后,如果再对子元素进行百分比计算时,计算的基础似乎是有继承性的(如果定位的数值是绝对数值没有这个问题,但是使用百分比计算的基础将不再是该元素的高度,而从父元素继承来的定位高度)。例如,我们有下面这样一个(X)HTML代码段:

ExampleSourceCode 

<DIVidDIVid="wrap"> 
<DIVidDIVid="subwrap"> 
<DIVidDIVid="content"> 
</DIV> 
</DIV> 
</DIV> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.

   如果我们对subwrap进行了绝对定位,那么content也会继承了这个这个属性,虽然它不会在页面中马上显示出来,但是如果再对content进行相对定位的时候,你使用的100%分比将不再是content原有的高度。例如,我们设定了subwrap的position为40%,我们如果想使content的上边缘和wrap重合的话就必须设置top:-80%;那么,如果我们设定subwrap的top:50%的话,我们必须使用100%才能使content回到原来的位置上去,但是如果我们把content也设置50%呢?那么它就正好垂直居中了。所以我们可以使用这中方法来实现InternetExplorer6中的垂直居中:

ExampleSourceCode 

DIV#wrap{  
border:1pxsolid#FF0099;  
background-color:#FFCCFF;  
width:760px;  
height:400px;  
position:relative;  
}  
DIV#subwrap{  
position:absolute;  
border:1pxsolid#000;  
top:50%;  
}  
DIV#content{  
border:1pxsolid#000;  
position:relative;  
top:-50%;  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.

  当然,这段代码只能在InternetExlporer6等计算存在问题的浏览器中才会有作用。(不过我不解,我查阅了很多文章,不知道是因为出处相同还是什么原因,似乎很多人都不愿意去解释InternetExlporer6中这这个Bug的原理,我也只是了解了一点皮毛,还要再研究)

SourceCodetoRun 

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>52CSS.com</title> 
<metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> 
<styletypestyletype="text/css"> 
 body{font-size:12px;font-family:tahoma;}  
 DIV#wrap{  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
  height:400px;  
  position:relative;  
 }  
 DIV#subwrap{  
  position:absolute;  
  top:50%;  
 }  
 DIV#content{  
  position:relative;  
  top:-50%;  
 }  
</style> 
</head> 
 
<body> 
<DIVidDIVid="wrap"> 
 <DIVidDIVid="subwrap"> 
  <DIVidDIVid="content"><pre>现在我们要使这段文字垂直居中显示!  
 DIV#wrap{  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
  height:500px;  
  position:relative;  
 }  
 DIV#subwrap{  
  position:absolute;  
  border:1pxsolid#000;  
  top:50%;  
 }  
 DIV#content{  
  border:1pxsolid#000;  
  position:relative;  
  top:-50%;  
 }</pre> 
  </DIV> 
 </DIV> 
</DIV> 
</body> 
</html> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.

[可先修改部分代码再运行查看效果]#p#

五、***的解决方案

  那么我们综合上面两种方法就可以得到一个***的解决方案,不过这要用到CSShack的知识。

ExampleSourceCode

DIV#wrap{  
display:table;  
border:1pxsolid#FF0099;  
background-color:#FFCCFF;  
width:760px;  
height:400px;  
_position:relative;  
overflow:hidden;  
}  
DIV#subwrap{  
vertical-align:middle;  
display:table-cell;  
_position:absolute;  
_top:50%;  
}  
DIV#content{  
_position:relative;  
_top:-50%;  
}  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.

  至此,一个***的居中方案就产生了。

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>52CSS.com</title> 
<metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> 
<styletypestyletype="text/css"> 
 body{font-size:12px;font-family:tahoma;}  
 DIV#wrap{  
  display:table;  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
  height:400px;  
  _position:relative;  
  overflow:hidden;  
 }  
 DIV#subwrap{  
  vertical-align:middle;  
  display:table-cell;  
  _position:absolute;  
  _top:50%;  
 }  
 DIV#content{  
  _position:relative;  
  _top:-50%;  
 }  
</style> 
</head> 
 
<body> 
<DIVidDIVid="wrap"> 
 <DIVidDIVid="subwrap"> 
  <DIVidDIVid="content"><pre>现在我们要使这段文字垂直居中显示!  
 DIV#wrap{  
  border:1pxsolid#FF0099;  
  background-color:#FFCCFF;  
  width:760px;  
  height:500px;  
  position:relative;  
 }  
 DIV#subwrap{  
  position:absolute;  
  border:1pxsolid#000;  
  top:50%;  
 }  
 DIV#content{  
  border:1pxsolid#000;  
  position:relative;  
  top:-50%;  
 }</pre> 
  </DIV> 
 </DIV> 
</DIV> 
</body> 
</html> 
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.

[可先修改部分代码再运行查看效果]

  垂直居中vertical-align的值是middle,而水平居中align的值是center,虽然同是居中但关键字不同。
 

【编辑推荐】

  1. DIV+CSS网页布局对SEO的四大影响
  2. 四种方法轻松实现CSS隔行换色
  3. CSS布局中float和position属性使用技巧
  4. CSS Sprites对CSS布局的意义及优缺点 
  5. CSS布局中display:inline-block属性用法详解

 

 

责任编辑:佚名 来源: 52css.com
相关推荐

2010-09-10 13:58:38

DIV图片居中

2010-08-31 15:07:45

CSS居中

2010-08-16 16:07:30

DIV垂直居中

2010-08-27 10:30:16

CSS垂直居中

2010-08-31 14:49:57

CSS居中

2010-09-02 13:16:44

CSS水平居中

2010-08-23 10:43:21

DIVCSS

2010-09-06 15:46:08

CSSDIV

2010-08-17 13:08:31

DIV+CSS布局

2010-08-16 16:49:30

DIV CSS居中

2010-08-24 14:23:39

DIV居中

2010-09-09 10:23:23

DIVCSS垂直居中

2010-08-26 11:27:35

CSS居中

2010-08-16 16:39:48

DIV内容居中

2010-08-24 14:47:48

CSS居中

2010-09-15 12:32:23

DIV页面

2010-09-09 10:15:35

DIVCSS

2010-09-01 10:49:57

CSS水平居中垂直居中

2021-07-26 08:31:17

算法

2010-09-10 09:31:08

CSSDIV
点赞
收藏

51CTO技术栈公众号