CSS 代码如何在一个div内让文字垂直居中

如题,注意不是要用行高,如果用的是行高,我输入的是两行文字就...你懂的。
CSS代码好像没有像表格单元格的属性valign属性的。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>水平+垂直居中</title>
<style type="text/css">
div {
font-family: "microsoft yahei";
border: 5px solid #cce800;
}
.container {
width: 600px;
padding: 10px;
margin: 10px auto;
background-color: gray;
}
.vertical {
display: table-cell;
height: 400px;
padding: 5px;
text-indent: 2em;
vertical-align: middle;
background-color: #cce8cf;
border-radius: 5px;
}
</style>
</head>
<body>
<!-- 外层这个是为了实现水平居中 -->
<div class="container">
<div class="vertical">
测试垂直居中,即便是多行,我也还是垂直居中对齐的。
<h3>问题分析:</h3>
<p>1.CSS中vertical-align这个属性只是对行级元素生效,div是块级元素,所以即使设置了此属性也不会生效。</p>
<p>2.Div可以通过display属性中的table-cell值由块级元素变为行级元素(这里你可以理解为Excel里的单元格),这样就支持vertical-align的垂直居中了。</p>
<p>3.扩张一点:如果是行级元素(例如span),也可以通过把height和line-height设置为相同值,这样也可以实现垂直居中,不过不符合你的要求,你了解即可。</p>
</div>
</div>

</body>
</html>

下边是运行出来的效果:

问题分析:

    CSS中vertical-align这个属性只是对行级元素生效,div是块级元素,所以即使设置了此属性也不会生效。

    Div可以通过display属性中的table-cell值由块级元素变为行级元素(这里你可以理解为Excel里的单元格),这样就支持vertical-align的垂直居中了。

    扩展一点:如果是行级元素(例如span),也可以通过把height和line-height设置为相同值,这样也可以实现垂直居中,不过不符合你的要求,你了解即可。


另外哥推荐你用sublime写前端代码,灰常不错的一款编辑器,骚年,哥能帮你的就这么多了,剩下自己努力吧。

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-09-01
让div的height设置为auto,或者不设置高度(高度默认值为auto),然后设置div的上下padding值相等。
比如:
div {
padding:20px;/*或者padding-top:20px;padding-bottom:20px;*/
height:auto;
}追问

好像记的padding 在ie6和ie8有差异的

追答

padding 在ie6和ie8有差异是因为盒模型解释不同,你可以用标准模式。

本回答被提问者和网友采纳
第2个回答  推荐于2017-09-10

由于div 是块级元素,在css中并没有可以使块级元素内的元素垂直居中的属性。所以只能使用其他的方法。

    设置文字的padding,使其达到居中的效果。、

    在文字外层,div内包裹一个<p>标签,<div><p>只是一段文字</p></div>并将p标签的大小设置的与div标签同样大小。再对p标签应用vertical-align :middle属性。

    具体如下:

    p{
    width:100%;
     height:100%;
    vertical-align:middle;}/*注意当p标签的height为百分比写法时,div标签的height不要使用百分比的写法*/

第3个回答  2012-11-15
使用vertical-align属性,和table那个垂直居中差不多
div { vertical-align : middle; }
第4个回答  2012-11-22
.div{
/* 文字垂直居中
给包含它的父元素一个高度/宽度
然后padding:50% 0;
*/
/* 文字水平居中
text-align:center;
*/

}
相似回答