css樣式實現物件的垂直居中(方法彙總與對比)

2022-08-02 01:12:11 字數 1581 閱讀 7913

方法一這個方法把一些 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 三 多行文字在確定容器中垂直居中 一大段文字 未知高度 要在已...