div垂直居中的N種方法 單行/多行文字(未知高度/固定高度)

說到這個問題的時候,也許有人會問CSS中不是有vertical-align屬性來設置垂直居中的嗎?即便是某些瀏覽器不支持我只需作少量的 CSSHack技術就能夠啊!因此在這裏我還要囉嗦兩句,CSS中的確是有vertical-align屬性,可是它只對(X)HTML元素中擁有 valign特性的元素才生 效,例如表格元素中的<td>、<th>、<caption>等,而 像<div>、<span>這樣的元素是沒有valign特性的,所以使用vertical-align對它們不起做用。
1、單行垂直居中
若是一個容器中只有一行文字,對它實現居中相對比較簡單,咱們只須要設置它的實際高度height和所在行的高度line-height相等便可。
如:

php

複製代碼
代碼以下:

div{
height:25px;
line-height:25px;
overflow:hidden;
}


這段代碼很簡,後面使用overflow:hidden的設置是爲了防止內容超出容器或者產生自動換行,這樣就達不到垂直居中效果了。更多CSS教
程。

css

複製代碼
代碼以下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>單行文字實現垂直居中</title>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<styletype="text/css">
body{font-size:12px;font-family:tahoma;}
div{
height:25px;
line-height:25px;
border:1pxsolid#FF0099;

}
</style>
</head>
<body>
<div>如今咱們要使這段文字垂直居中顯示!</div>
</body>
</html>


2、多行未知高度文字的垂直居中
若是一段內容,它的高度是可變的那麼咱們就可使用上一節講到的實現水平居中時使用到的最後一種方法,就是設定Padding,使上下的
padding值相同便可。一樣的,這也是一種「看起來」的垂直居中方式,它只不過是使文字把<div>徹底填充的一種訪求而已。可使用相似下
面的代碼:

html

複製代碼
代碼以下:

div{
padding:25px;
}


這種方法的優勢就是它能夠在任何瀏覽器上運行,而且代碼很簡單,只不過這種方法應用的前提就是容器的高度必須是可伸縮的。

瀏覽器

複製代碼
代碼以下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>多行文字實現垂直居中</title>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<styletype="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>


3、多行文本固定高度的居中
在 本文的一開始,咱們已經說過CSS中的vertical-align屬性只會對擁有valign特性的(X)HTML標籤起做用,可是在CSS中還有一個 display屬性可以模擬<table>,因此咱們可使用這個屬性來讓<div>模擬<table>就可使用 vertical-align了。注意,display:table和display:table-cell的使用方法,前者必須設置在父元素上,後者必 須設置在子元素上,所以咱們要爲須要定位的文本再增長一個<div>元素:

性能

複製代碼
代碼以下:

div#wrap{
height:400px;
display:table;
}
div#content{
vertical-align:middle;
display:table-cell;
border:1pxsolid#FF0099;

width:760px;
}



複製代碼
代碼以下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>多行文字實現垂直居中</title>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<styletype="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;

width:760px;
}
</style>
</head>
<body>
<divid="wrap">
<divid="content"><pre>如今咱們要使這段文字垂直居中顯示!Webjx.Com
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>


這 個方法應該是很理想了,可是不幸的是InternetExplorer6並不能正確地理解display:table和display:table- cell,所以這種方法在InternetExplorer6及如下的版本中是無效的。嗯,這讓人很鬱悶!不過咱們還其它的辦法
4、在InternetExplorer中的解決方案
在 InternetExplorer6及如下版本中,在高度的計算上存在着缺陷的。在InternetExplorer6中對父元素進行定位後,若是再對子 元素進行百分比計算時,計算的基礎彷佛是有繼承性的(若是定位的數值是絕對數值沒有這個問題,可是使用百分比計算的基礎將再也不是該元素的高度,而從父元素 繼承來的定位高度)。例如,咱們有下面這樣一個(X)HTML代碼段:

ui

複製代碼
代碼以下:

<divid="wrap">
<divid="subwrap">
<divid="content">
</div>
</div>
</div>


如 果咱們對subwrap進行了絕對定位,那麼content也會繼承了這個這個屬性,雖然它不會在頁面中立刻顯示出來,可是若是再對content進行相 對定位的時候,你使用的100%分比將再也不是content原有的高度。例如,咱們設定了subwrap的position爲40%,咱們若是想使 content的上邊緣和wrap重合的話就必須設置top:-80%;那麼,若是咱們設定subwrap的top:50%的話,咱們必須使用100%才 能使content回到原來的位置上去 ,可是若是咱們把content也設置50%呢?那麼它就正好垂直居中了。因此咱們可使用這中方法來實現InternetExplorer6中的垂直居 中:

spa

複製代碼
代碼以下:

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%;
}


當 然,這段代碼只能在InternetExlporer6等計算存在問題的瀏覽器中才會有做用。(不過我不解,我查閱了不少文章,不知道是由於出處相同仍是 什麼緣由,彷佛不少人都不肯意去解釋InternetExlporer6中這這個Bug的原理,我也只是瞭解了一點皮毛,還要再研究)

code

複製代碼
代碼以下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>多行文字實現垂直居中</title>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<styletype="text/css">
body{font-size:12px;font-family:tahoma;}
div#wrap{
border:1pxsolid#FF0099;

width:760px;
height:400px;
position:relative;
}
div#subwrap{
position:absolute;
top:50%;
}
div#content{
position:relative;
top:-50%;
}
</style>
</head>
<body>
<divid="wrap">
<divid="subwrap">
<divid="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>


5、完美的解決方案
那麼咱們綜合上面兩種方法就能夠獲得一個完美的解決方案,不過這要用到CSShack的知識。對於若是使用CSSHack來區分瀏覽器,你能夠參考這篇「簡單CSShack:區分IE六、IE七、IE八、Firefox、Opera」:

xml

複製代碼
代碼以下:

div#wrap{
display:table;
border:1pxsolid#FF0099;

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%;
}


至此,一個完美的居中方案就產生了。

htm

複製代碼
代碼以下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>多行文字實現垂直居中</title>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<styletype="text/css">
body{font-size:12px;font-family:tahoma;}
div#wrap{
display:table;
border:1pxsolid#FF0099;

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>
<divid="wrap">
<divid="subwrap">
<divid="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>

p.s.垂直居中vertical-align的值是middle,而水平居中align的值是center,雖然同是居中但關鍵字不一樣

相關文章
相關標籤/搜索