div中的文字水平居中:text-align:center;即可。
div中的文字垂直居中:line-height:值。值等於div的高度。
text-indent:2em;//首航縮進2字符
你們假設你的DIV是高度100PX,寬度是1000PX,那你這樣寫,你的文字就會水平垂直居中:
<div style="width:1000px; height:100px; text-align:center; line-height:100px; border:blue solid 1px;">
水平垂直居中
</div>
CSS是這樣的,text-align:center意思就是說,讓這個DIV裏的文字水平居中,而line-height:100px;的意思是說,讓DIV裏面的每一行文字,佔的高度爲100PX(和那個DIV的高度一樣),這樣,文字就垂直居中了。也就是說,如果你的DIV是200PX高,那你就讓line-height:200px;文字就會垂直居中了。
這裏再總結一下幾個比較常見的處理方式。
情形一:div限高,內容長度限一
<style>
.v-align {
margin: 0 auto;
width: 200px;
height: 80px;
text-align: center;
line-height: 80px;
border: 1px solid #ddd;
}
</style>
<!-- html -->
<div class="v-align">我的內容只能有一行。</div>
情形二:div限高,內容不限
.v-mult {
margin: 0 auto;
width: 200px;
height: 100px;
border: 1px solid #ddd;
overflow: hidden;
}
.v-mult .empty,
.v-mult .text {
display: inline-block;
*display: inline;
*zoom: 1;
vertical-align: middle;
}
.v-mult .empty {
height: 100%;
}
<!-- html -->
<div class="v-mult">
<span class="empty"></span>
<span class="text">我的內容不限,多高都行
換行照常</span>
</div>
情形三:div高度不定,內容高度一定
.v-auto {
position: relative;
margin: 0 auto;
width: 200px;
border: 1px solid #ddd;
}
.v-auto .text {
position: absolute;
top: 50%;
margin-top: -50px;
height: 100px;
border: 1px dashed #ddd;
}
<!-- html -->
<div class="v-auto">
<div class="text">
我的高度是固定的,只有100px高,但是我的父及高度不定,我怎麼垂直居中呢?
</div></div>
情形四:div高度不定,內容高度不定
.v-auto-out {
position: relative;
margin: 0 auto;
width: 200px;
border: 1px solid #ddd;
}
.v-auto-out .auto-in {
position: absolute;
top: 50%;
border: 1px dashed #ddd;
/* 這裏有兼容性問題 */
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
-o-transform: translateY(-50%);
transform: translateY(-50%);
}
<!-- html -->
<div class="v-auto-out">
<div class="auto-in">我的高度不定,我的父及高度也不定,這下要上下居中,該如何是好?我們一起來瞧瞧吧。</div>
</div>
另外div套div上下左右居中方法:http://www.divcss5.com/wenji/w50230.shtml