方法一這個方法把一些 div 的顯示方式設定為**,因此我們可以使用**的 vertical-align property 屬性。
content goes here
#cell
優點:缺點:
internet explorer(甚至 ie8 beta)中無效,許多巢狀標籤(其實沒那麼糟糕,另乙個專題)
方法二:
這個方法使用絕對定位的 div,把它的 top 設定為 50%,top margin 設定為負的 content 高度。這意味著物件必須在 css 中指定固定的高度。
因為有固定高度,或許你想給 content 指定 overflow:auto,這樣如果 content 太多的話,就會出現滾動條,以免content 溢位。
content goes here
#content
優點:
適用於所有瀏覽器
不需要巢狀標籤
缺點:
沒有足夠空間時,content 會消失(類似div 在 body 內,當使用者縮小瀏覽器視窗,滾動條不出現的情況)
方法三這種方法,在 content 元素外插入乙個 div。設定此 div height:50%; margin-bottom:-contentheight;。
content 清除浮動,並顯示在中間。
content here
#floater#content
優點:
適用於所有瀏覽器
沒有足夠空間時(例如:視窗縮小) content 不會被截斷,滾動條出現
缺點:
唯一我能想到的就是需要額外的空元素了(也沒那麼糟,又是另外乙個話題)
方法四這個方法使用了乙個 position:absolute,有固定寬度和高度的 div。這個 div 被設定為 top:0;
bottom:0;。但是因為它有固定高度,其實並不能和上下都間距為 0,因此 margin:auto; 會使它居中。使用
margin:auto;使塊級元素垂直居中是很簡單的。
content here
#content
優點:
簡單缺點:
ie(ie8 beta)中無效
無足夠空間時,content 被截斷,但是不會有滾動條出現
方法五這個方法只能將單行文字置中。只需要簡單地把 line-height 設定為那個物件的 height 值就可以使文字居中了。
content here
#content
優點:
適用於所有瀏覽器
無足夠空間時不會被截斷
缺點:
只對文字有效(塊級元素無效)
多行時,斷詞比較糟糕
這個方法在小元素上非常有用,例如使按鈕文字或者單行文字居中。
CSS垂直居中水平居中方法
center 剛在別人的部落格裡看到這種方法時真的覺得很奇葩,以下是大神的解釋 解釋 1 在普通內容流中,margin auto的效果等同於margin top 0 margin bottom 0。2 position absolute使絕對定位塊跳出了內容流,內容流中的其餘部分渲染時絕對定位部分不...
CSS 關於實現垂直居中方法總結
專案裡經常在元素排列時會需要垂直居中的情況,以下在使用場景和條件限制上總結部分常用的一些垂直居中方法。將元素的height和line height設定為相同的值即可 利用display table cell賦予div類似於table等標籤的 布局特性,middle 複製 此方法相容所有瀏覽器 關於t...
css 垂直居中方法整理
知道vertical align屬性吧,css中用來設定垂直居中的。但它只針對有vertical特性的元素,像 而這些要用垂直居中的時候只能另外找方法了。一 單行在確定的容器中垂直居中 div 二 多行文字在不確定容器中垂直居中 div 三 多行文字在確定容器中垂直居中 一大段文字 未知高度 要在已...