雖然div中內(nèi)容上下居中的問(wèn)題已經(jīng)是一個(gè)比較古老的話題,但是最近發(fā)現(xiàn)還是有很多前端開(kāi)發(fā)者在詢問(wèn)如何實(shí)現(xiàn)。其實(shí)網(wǎng)絡(luò)上已經(jīng)有很多資料和案例了,我這里再總結(jié)一下幾個(gè)比較常見(jiàn)的處理方式。
情形一:div限高,內(nèi)容長(zhǎng)度限一行
代碼如下:
<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">我的內(nèi)容只能有一行。</div>
valign_1
情形二:div限高,內(nèi)容不限
代碼如下:
.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">我的內(nèi)容不限,多高都行
換行照常</span>
</div>
valign_2
情形三:div高度不定,內(nèi)容高度一定
代碼如下:
.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>
valign_3
情形四:div高度不定,內(nèi)容高度不定
代碼如下:
.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;
/* 這里有兼容性問(wèn)題 */
-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">我的高度不定,我的父及高度也不定,這下要上下居中,該如何是好?我們一起來(lái)瞧瞧吧。</div>
</div>
valign_4
好了,知道這四種方式,我相信足以應(yīng)對(duì)日常工作中的各種垂直居中問(wèn)題。代碼很簡(jiǎn)單,不再做多余闡述??傊痪湓?,CSS的各個(gè)屬性樣式,就好像人肢體的各個(gè)器官,了解了各個(gè)器官的功能,才能相互配合完成各種任務(wù)。相反,個(gè)體的能力是有限的。
更多信息請(qǐng)查看IT技術(shù)專欄