成人免费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-06 10:04:31

CSS樣式表

2010-09-02 10:55:57

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技術棧公眾號

主站蜘蛛池模板: 不卡一二区 | 亚洲精品91 | 一区二区免费 | 黄色激情毛片 | 国产精品久久久久久久久久久久久久 | 日韩中文字幕一区二区 | 久久精品视频在线免费观看 | 精品一区国产 | 狠狠操电影 | 久久精品亚洲成在人线av网址 | 亚洲精品成人免费 | 日韩欧美不卡 | 91av精品 | 国产成人精品a视频一区www | 久久亚洲91 | 久久午夜影院 | 欧美涩 | 日本a级大片 | 亚洲欧美一区二区三区在线 | 91视频88av | 免费成人高清 | 国产精品国产精品国产专区不蜜 | 日韩精品一区在线观看 | 亚洲欧美一区二区三区视频 | av天天干| 国产片侵犯亲女视频播放 | 午夜精品导航 | 日韩精品免费视频 | 久久久久国产视频 | 自拍偷拍中文字幕 | 日韩成人免费 | 精品福利在线 | 米奇7777狠狠狠狠视频 | 范冰冰一级做a爰片久久毛片 | 日韩1区 | 日韩在线观看一区 | 日韩电影在线一区 | 精品国产免费人成在线观看 | 东方伊人免费在线观看 | 国产一区二区三区在线免费观看 | 国产精品久久久久久久久久久久 |