在說到這個問題的時候,也許有人會問css中不是有vertical-align屬性來設定垂直居中的嗎?即使是某些瀏覽器不支援我只需做少許的css hack技術就可以啊!所以在這裡我還要囉嗦兩句,css中的確是有vertical-align屬性,但是它只對(x)html元素中擁有valign特性的元素才生效,例如**元素中的
、、等,而像、這樣的元素是沒有valign特性的,因此使用vertical-align對它們不起作用。
tips: 完美解決方案在文末!
一、單行垂直居中
如果乙個容器中只有一行文字,對它實現居中相對比較簡單,我們只需要設定它的實際高度height和所在行的高度line-height相等即可。
如: xml/html code複製內容到剪貼簿
這段**很簡,後面使用overflow:hidden的設定是為了防止內容超出容器或者產生自動換行,這樣就達不到垂直居中效果了。
xml/html code複製內容到剪貼簿
二、多行未知高度文字的垂直居中
如果一段內容,它的高度是可變的那麼我們就可以使用上一節講到的實現水平居中時使用到的最後一種方法,就是設定padding,使上下www.cppcns.com的padding值相同即可。同樣的,這也是一種「看起來」的垂直居中方式,它只不過是使文字把
完全填充的一種訪求而已。可以使用類似下面的**:
css code複製內容到剪貼簿
這種方法的優點就是它可以在任何瀏覽器上執行,並且**很簡單,只不過這種方法應用的前提就是容器的高度必須是可伸縮的。
xml/html code複製內容到剪貼簿
三、多行文字固定高度的居中
在本文的一開始,我們已經說過css中的vertical-align屬性只會對擁有valign特性的(x)html標籤起作用,但是在css中還有乙個display屬性能夠模擬
,所以我們可以使用這個屬性來讓模擬就可以使用vertical-align了。注意,display:table和display:table-cell的使用方法,前者必須設定在父元素上,後者必須設定在子元素上,因此我們要為需要定位的文字再增加乙個元素:
css code複製內容到剪貼簿
xml/html code複製內容到剪貼簿
這個方法應該是很理想了,但是不幸的是internet explorer 6 並不能正確地理解display:table和display:table-cell,因此這種方法在internet explorer 6及以下的版本中是無效的。嗯,這讓人很鬱悶!不過我們還其它的辦法。
四、在internet explorer中的解決方案
在internet explorer 6及以下版本中,在高度的計算上存在著缺陷的。在internet explorer 6中對父元素進行定位後,如果再對子元素進行百分比計算時,計算的基礎似乎是有繼承性的(如果定位的數值是絕對數值沒有這個問題,但是使用百分比計算的基礎將不再是該元素的高度,而從父元素繼承來的定位高度)。
例如,我們有下面這樣乙個(x)html**段:
css code複製內容到剪貼簿
如果我們對subwrap進行了絕對定位,那麼content也會繼承了這個這個屬性,雖然它不會在頁面中馬上顯示出來,但是如果再對content進行相對定位的時候,你使用的100%分比將不再是content原有的高度。例如,我們設定了subwrap的position為40%,我們如果想使content的上邊緣和wrap重合的話就必須設定top:-80%;那麼,如果我們設定subwrap的top:50%的話,我們必須使用100%才能使content回到原來的位置上去,但是如果我們把content也設定50%呢?那麼它就正好垂直居中了。所以我們可以使用這中方法來實現internet explorer 6中的垂直居中:
css code複製內容到剪貼簿
當然,這段**只能在internet exlporer 6等計算存在問題的瀏覽器中才會有作用。(不過我不解,我查閱了很多文章,不知道是因為出處相同還是什麼原因,似乎很多人都不願意去解釋internet exlporer 6中這這個bug的原理,我也只是了解了一點皮毛,還要再研究)
xml/html code複製內容到剪貼簿
五、完美的解決方案
那麼我們綜合上面兩種方法就可以得到乙個完美的解決方案,不過這要用到css hack的知識。
css code複製內容到剪貼簿
至此,乙個完美的居中方案就產生了。
xml/html code複製內容到剪貼簿
ps:垂直居中vertical-align的值是middle,而水平居中align的值是center,雖然同是居中但關鍵字不同。
六、實測可以完美實現各種瀏覽器相容的居中方案
下面這段**經過實測,可以完美相容ie7以上的ie瀏覽器,其它標準瀏覽器如火狐、谷歌等也沒有問題。
說明:儘管有css的vertical-align特性,但是並不能有效解決未知高度的垂直居中問題(在乙個div標籤裡有未知高度的文字或的情況下)。標準瀏覽器如mozilla, opera, safari等.,可將父級元素顯示方式設定為table(display: table;) ,內部子元素定為table-cell (display: table-cell),通過vertical-align特性使其垂直居中,但非標準瀏覽器是不支援的。非標準瀏覽器只能在子元素裡設距頂部50%,裡面再套個元素距頂部-50% 來抵消。
xml/html code複製內容到剪貼簿
以上css**的優點是沒有hacks,採用了ie不支援的css2選擇器#value[id]。
css2選擇器#value[id]相當於選擇器#value,但是internet explorer不支援這種型別的選擇器。同樣地.value[class],相當於.value,這些只有標準瀏覽器能讀懂。
測試:firefox1.5、opera9.0、ie6.0、ie5.0通過。上面的**不支援ie7,還需要在最下面加二句:
*+html #outer[id]
*+html #middle[id]
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。
本文標題: css設定div垂直居中的n種方法 相容ie瀏覽器
本文位址:
點讚打賞
分享如果認為本文對您有所幫助請贊助本站
宣告:凡註明"本站原創"的所有文字等資料,版權均屬程式設計客棧所有,歡迎**,但務請註明出處。
標籤:css div 垂直 居中
css學習筆記之常用mixin封裝例項**css3 3d位移translate效果例項介紹
您可能感興趣的文章:
廣告贊助
廣告贊助
最新發布
全站最新
廣而告之
© 2018-2021 程式設計客棧 贛icp備17006162號-9
贛公網安備 36110202000251號
top
DIV 設定垂直居中
要說面試官經常問的問題中 如何將乙個塊元素水平垂直居中 就算乙個。之前的面試中也有中招,現在總結一下。1 css垂直水平居中 要讓div水平和垂直居中,必需知道該div得寬度和高度,然後設定位置為絕對位置,距離頁面視窗左邊框和上邊框的距離設定為50 這個50 就是指頁面視窗的寬度和高度的50 最後將...
CSS教程 div垂直居中的N種方法
在說到這個問題的時候,也許有人會問css中不是有vertical align屬性來設定垂直居中的嗎?即使是某些瀏覽器不支援我只需做少許的css hack技術就可以啊!所以在這裡我還要囉嗦兩句,css中的確是有vertical align屬性,但是它只對 x html元素中擁有valign特性的元素才...
css實現div水平 垂直居中
示例1 chrome33 ie8測試通過 示例2 chrome33 ie8測試通過 示例4 chrome33測試通過,ie8測試不通過,參考 注 對頁面中所有元素應用box sizing border box樣式是為了將padding margin值都計入width height中,即為元素指定的任...