在前面的文章中我簡單總結(jié)了一個“CSS在頁面布局中實現(xiàn)div水平居中的方法”,其實水平居中實現(xiàn)還是比較簡單的,反而垂直居中有點麻煩,因為我們設(shè)計頁面的時候往往水平寬度都是固定的。因此我們有必要總結(jié)一下在頁面布局過程中實現(xiàn)垂直居中的方法。
在說到這個問題的時候,也許有人會問CSS中不是有vertical-align屬性來設(shè)置垂直居中的嗎?即使是某些瀏覽器不支持我只需做少許的CSS Hack技術(shù)就可以啊!所以在這里我還要啰嗦兩句,CSS中的確是有vertical-align屬性,但是它只對(X)HTML元素中擁有valign特性的元素才生效,例如表格元素中的<td>、<th>、<caption>等,而像<div>、<span>這樣的元素是沒有valign特性的,因此使用vertical-align對它們不起作用。
一、單行垂直居中
如果一個容器中只有一行文字,對它實現(xiàn)居中相對比較簡單,我們只需要設(shè)置它的實際高度height和所在行的高度line-height相等即可。如:
div {
height:25px;
line-height:25px;
overflow:hidden;
}
這段代碼很簡,后面使用overflow:hidden的設(shè)置是為了防止內(nèi)容超出容器或者產(chǎn)生自動換行,這樣就達不到垂直居中效果了。更多CSS教程。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title> 單行文字實現(xiàn)垂直居中 </title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
body { font-size:12px;font-family:tahoma;}
div {
height:25px;
line-height:25px;
border:1px solid #FF0099;
background-color:#FFCCFF;
}
</style>
</head>
<body>
<div>現(xiàn)在我們要使這段文字垂直居中顯示!</div>
</body>
</html>
不過在Internet Explorer 6及以下版本中,這和方法不支持對圖片設(shè)置垂直居中。
二、多行未知高度文字的垂直居中
如果一段內(nèi)容,它的高度是可變的那么我們就可以使用上一節(jié)講到的實現(xiàn)水平居中時使用到的最后一種方法,就是設(shè)定Padding,使上下的padding值相同即可。同樣的,這也是一種“看起來”的垂直居中方式,它只不過是使文字把<div>完全填充的一種訪求而已。可以使用類似下面的代碼:
div {
padding:25px;
}
這種方法的優(yōu)點就是它可以在任何瀏覽器上運行,并且代碼很簡單,只不過這種方法應(yīng)用的前提就是容器的高度必須是可伸縮的。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
新聞熱點
疑難解答