成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

5種方法解決CSS實現垂直居中問題

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

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

CSS實現垂直居中的5種方法

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

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

方法一

這個方法把一些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.  

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

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

方法二:

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

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

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

優點:

適用于所有瀏覽器

不需要嵌套標簽

缺點:

沒有足夠空間時,content會消失(類似div在body內,當用戶縮小瀏覽器窗口,滾動條不出現的情況)#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.  

優點:

適用于所有瀏覽器

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

缺點:

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

方法四

這個方法使用了一個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. }  

優點:簡單

缺點:

IE(IE8beta)中無效

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

方法五

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

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


優點:

適用于所有瀏覽器

無足夠空間時不會被截斷

缺點:

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

多行時,斷詞比較糟糕

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

【編輯推薦】

  1. 簡單實用的五個CSS屬性
  2. CSS層疊與繼承用法手冊
  3. DIV布局規范中CSS類及id命名方式
  4. CSS網頁布局中id與class命名規則
  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居中

2018-09-18 11:20:07

css html5javascript

2010-08-31 14:49:57

CSS居中

2010-09-02 13:03:38

CSS垂直居中

2010-09-01 10:49:57

CSS水平居中垂直居中

2022-12-20 15:17:29

CSS開發

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內容居中

2010-09-02 10:55:57

CSS

2010-09-06 10:04:31

CSS樣式表

2021-03-21 22:23:38

云計算數據中心IT

2019-12-16 16:50:13

Windows 10全屏開始菜單

2010-09-09 10:23:23

DIVCSS垂直居中

2010-08-26 14:18:25

DIV高度

2010-08-26 16:19:41

DIV圓角

2010-08-24 14:23:39

DIV居中
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品一区二区在线 | 韩国主播午夜大尺度福利 | 亚洲综合色视频在线观看 | a视频在线播放 | 欧美一区二区免费视频 | 国产91在线精品 | av资源中文在线天堂 | 中文字幕一级毛片 | 天天操天天射天天 | 91国内精精品久久久久久婷婷 | 国产乱码一区 | 久久国产精品一区 | 黄免费观看视频 | 日韩中文字幕一区二区 | 欧美日韩中文国产一区发布 | 亚洲国产福利视频 | 羞羞网站免费观看 | 久久久国产一区二区三区四区小说 | 久久成人免费视频 | 国产精产国品一二三产区视频 | 国产精品永久 | 超碰在线免费av | 亚洲天堂中文字幕 | 欧美一级黄视频 | 亚洲一区在线播放 | 亚洲精品一区二区久 | 国产视频综合 | 日本久久网 | 亚洲视频一区二区 | 久久久久久久久久久久久9999 | 欧美日韩在线免费 | 色综合中文 | 久久精品国产亚洲夜色av网站 | 欧美一级黄带 | 日韩中文字幕 | 亚洲精品一区二区在线观看 | 91精品国产91久久久久久吃药 | 国产精品成人久久久久 | 国产一区二区三区四区在线观看 | 精品国产精品国产偷麻豆 | 国产精品网址 |