自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

5種方法解決CSS實現(xiàn)垂直居中問題

開發(fā) 前端
利用CSS來實現(xiàn)對象的垂直居中有許多不同的方法,本文向大家介紹一下使對象垂直集中的5種不同方法,以及它們各自的優(yōu)缺點。

你對CSS實現(xiàn)垂直居中的方法是否了解,使用CSS實現(xiàn)垂直居中并不容易,有些方法在一些瀏覽器中無效,這里分享一下5種實現(xiàn)CSS垂直居中的方法及優(yōu)缺點。

CSS實現(xiàn)垂直居中的5種方法

利用CSS來實現(xiàn)對象的垂直居中有許多不同的方法,比較難的是選擇那個正確的方法。我下面說明一下我看到的好的方法和怎么來創(chuàng)建一個好的居中網(wǎng)站。

使用CSS實現(xiàn)垂直居中并不容易。有些方法在一些瀏覽器中無效。下面我們看一下使對象垂直集中的5種不同方法,以及它們各自的優(yōu)缺點。(可以看看測試頁面,有簡短解釋。)

方法一

這個方法把一些div的顯示方式設置為表格,因此我們可以使用表格的vertical-alignproperty屬性。

  1. <dividdivid="wrapper"> 
  2. <dividdivid="cell"> 
  3. <divclassdivclass="content"> 
  4. Contentgoesherediv> 
  5. div> 
  6. div> 
  7. #wrapper{display:table;}  
  8. #cell{display:table-cell;vertical-align:middle;}  
  9.  

優(yōu)點:content可以動態(tài)改變高度(不需在CSS中定義)。當wrapper里沒有足夠空間時,content不會被截斷

缺點:InternetExplorer(甚至IE8beta)中無效,許多嵌套標簽(其實沒那么糟糕,另一個專題)

方法二:

這個方法使用絕對定位的div,把它的top設置為50%,topmargin設置為負的content高度。這意味著對象必須在CSS中指定固定的高度。

因為有固定高度,或許你想給content指定overflow:auto,這樣如果content太多的話,就會出現(xiàn)滾動條,以免content溢出。

  1. <divclassdivclass="content"> 
  2. Contentgoesherediv> 
  3. #content{  
  4. position:absolute;  
  5. top:50%;  
  6. height:240px;  
  7. margin-top:-120px;/*negativehalfoftheheight*/  
  8. }  
  9.  

優(yōu)點:

適用于所有瀏覽器

不需要嵌套標簽

缺點:

沒有足夠空間時,content會消失(類似div在body內(nèi),當用戶縮小瀏覽器窗口,滾動條不出現(xiàn)的情況)#p#

方法三

這種方法,在content元素外插入一個div。設置此divheight:50%;margin-bottom:-contentheight;。
content清除浮動,并顯示在中間。

  1. <dividdivid="floater"> 
  2. <dividdivid="content"> 
  3. Contentherediv> 
  4. div> 
  5. #floater{float:left;height:50%;margin-bottom:-120px;}  
  6. #content{clear:both;height:240px;position:relative;}  
  7.  

優(yōu)點:

適用于所有瀏覽器

沒有足夠空間時(例如:窗口縮小)content不會被截斷,滾動條出現(xiàn)

缺點:

唯一我能想到的就是需要額外的空元素了(也沒那么糟,又是另外一個話題)

方法四

這個方法使用了一個position:absolute,有固定寬度和高度的div。這個div被設置為top:0;bottom:0;。但是因為它有固定高度,其實并不能和上下都間距為0,因此margin:auto;會使它居中。使用margin:auto;使塊級元素垂直居中是很簡單的。

  1. <dividdivid="content"> 
  2. Contentherediv> 
  3. #content{  
  4. position:absolute;  
  5. top:0;  
  6. bottom:0;  
  7. left:0;  
  8. right:0;  
  9. margin:auto;  
  10. height:240px;  
  11. width:70%;  
  12. }  

優(yōu)點:簡單

缺點:

IE(IE8beta)中無效

無足夠空間時,content被截斷,但是不會有滾動條出現(xiàn)

方法五

這個方法只能將單行文本置中。只需要簡單地把line-height設置為那個對象的height值就可以使文本居中了。

  1. <dividdivid="content"> 
  2. Contentherediv> 
  3. #content{height:100px;line-height:100px;}  
  4.  


優(yōu)點:

適用于所有瀏覽器

無足夠空間時不會被截斷

缺點:

只對文本有效(塊級元素無效)

多行時,斷詞比較糟糕

這個方法在小元素上非常有用,例如使按鈕文本或者單行文本居中。

【編輯推薦】

  1. 簡單實用的五個CSS屬性
  2. CSS層疊與繼承用法手冊
  3. DIV布局規(guī)范中CSS類及id命名方式
  4. CSS網(wǎng)頁布局中id與class命名規(guī)則
  5. 將XHTML+CSS頁面轉換為打印機頁面技巧

 

責任編輯:佚名 來源: blueidea.com
相關推薦

2012-06-20 13:46:23

CSS

2021-07-26 08:31:17

算法

2010-08-24 14:47:48

CSS居中

2010-08-31 14:49:57

CSS居中

2018-09-18 11:20:07

css html5javascript

2010-09-01 10:49:57

CSS水平居中垂直居中

2010-09-02 13:03:38

CSS垂直居中

2022-12-20 15:17:29

CSS開發(fā)

2010-09-10 09:31:08

CSSDIV

2010-08-26 11:27:35

CSS居中

2010-08-16 16:07:30

DIV垂直居中

2010-08-16 16:39:48

DIV內(nèi)容居中

2010-09-06 10:04:31

CSS樣式表

2010-09-02 10:55:57

CSS

2010-09-09 10:23:23

DIVCSS垂直居中

2021-03-21 22:23:38

云計算數(shù)據(jù)中心IT

2019-12-16 16:50:13

Windows 10全屏開始菜單

2010-08-26 16:19:41

DIV圓角

2010-08-24 14:23:39

DIV居中

2010-08-26 14:18:25

DIV高度
點贊
收藏

51CTO技術棧公眾號