<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS垂直居中</title>
<style>
.wrapper{
width: 500px;
height: 500px;
background-color: pink;
text-align: center;
}
.box{
width: 100px;
height: 100px;
background-color: deepskyblue;
display: inline-block;
vertical-align: middle;
margin: 0 auto;
}
</style>
</head>
<body>
<div class="wrapper">
<div class="box"></div>
</div>
</body>
</html>

效果如圖所示
以前總是以為vertical-align與text-align是同樣的道理,一個是垂直居中,一個是水平居中,結(jié)果在這里一點(diǎn)效果也沒有。事實(shí)上vertical-align與text-align完全不一樣,vertical-align不能這樣用。
vertical-align 屬性設(shè)置元素的垂直對齊方式。該屬性定義行內(nèi)元素的基線相對于該元素所在行的基線的垂直對齊。允許指定負(fù)長度值和百分比值。這會使元素降低而不是升高。在表單元格中,這個屬性會設(shè)置單元格框中的單元格內(nèi)容的對齊方式。
第一種用法,先看后面一句“在表單元格中,這個屬性會設(shè)置單元格框中的單元格內(nèi)容的對齊方式?!边@很容易理解,如果給一個表格的td加一個vertical-align:middle的樣式,表格里面的內(nèi)容會垂直居中,同樣的如果給一個vertical-align:bottom就會底部對齊,如果給一個vertical-align:top就會頂部對齊。
第二種用法,該屬性定義行內(nèi)元素的基線相對于該元素所在行的基線的垂直對齊。假設(shè)有兩個行內(nèi)元素a和b,a和b都是div,當(dāng)a加了一個vertical-align:middle樣式之后,b的底部(基線)就會對齊a的中間位置,如下圖:

圖示
如果a和b都加了一個vertical-align:middle樣式,那么就互相對齊了對方的中間位置,也就是它們在垂直方向上的中線對齊了,如下圖:

圖示
現(xiàn)在我要讓class="box"的div在class="wrapper"的div里面垂直居中,我可以在class="wrapper"的div里面加一個div空標(biāo)簽,把它的高度設(shè)為100%,寬度設(shè)置為0,再給它一個vertical-align:middle樣式,同樣的給class="box"的div一個vertical-align:middle樣式,那么box就可以在div里面垂直居中了。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS垂直居中</title>
<style>
.wrapper{
width: 500px;
height: 500px;
background-color: pink;
text-align: center;
}
.box{
width: 100px;
height: 100px;
background-color: deepskyblue;
display: inline-block;
vertical-align: middle;
margin: 0 auto;
}
.help{
width: 0;
height: 100%;
display: inline-block;
vertical-align: middle;
}
</style>
</head>
<body>
<div class="wrapper">
<div class="box"></div>
<div class="help"></div>
</div>
</body>
</html>

圖示
下面我們來看一張圖來更好理解垂直對齊主要屬性值的表現(xiàn)形式

垂直對齊主要屬性值的表現(xiàn)形式.png