成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

vertical-align屬性與垂直居中

bergwhite / 2288人閱讀

摘要:方法二利用,設(shè)置元素結(jié)構(gòu),并應(yīng)用實(shí)現(xiàn)垂直居中,這種方法的實(shí)現(xiàn)可用于多行文本,要求及以上版本。

讓元素居中對(duì)齊是非常常見(jiàn)的需求,首先是水平居中,要實(shí)現(xiàn)水平居中行內(nèi)元素只需要在其父元素上設(shè)置text-align: center即可,對(duì)于塊級(jí)元素來(lái)說(shuō)讓它的margin-left: automargin-right: auto即可(width不可為auto),那么垂直居中呢?找下css屬性發(fā)現(xiàn)了vertical-align,感覺(jué)就是它了,設(shè)置個(gè)vertical-align: middle,怎么沒(méi)有達(dá)到預(yù)期效果?下面來(lái)詳細(xì)介紹下vertical-align這個(gè)屬性以及實(shí)現(xiàn)垂直居中的若干方法。

vertical-align屬性是干什么的

根據(jù)W3C Spec中對(duì)vertical-align屬性的定義:

  

This property affects the vertical positioning inside a line box of the boxes generated by an inline-level element.

什么是line box?同樣來(lái)自W3C Spec

  

The rectangular area that contains the boxes that form a line is called a line box.

這個(gè)屬性僅影響了單行中行內(nèi)元素的垂直位置,那么我們會(huì)涉及到的元素應(yīng)該是這樣的:

inline

inline-block

既然我們要垂直居中,垂直居中是相對(duì)于垂直高度而言的,然而我們知道height對(duì)inline元素?zé)o效,那么line box的高度是怎么計(jì)算的呢?(還是引用W3C Spec)

  

The height of a line box is determined by the rules given in the section on line height calculations.

一個(gè)line box的高度是的計(jì)算方式如下:line box中的每一個(gè)行內(nèi)元素都將加入到計(jì)算過(guò)程,如果是元素inline的則取其line-height的值,如果元素是inline-block或者是inline-table則取其margin-box的高度,最后這些值的最大值,即為line box的高度了。

好了,然后來(lái)看看vertical-align屬性可以取哪些值:

可取值 說(shuō)明
baseline 將元素的基線與父元素的基線對(duì)齊
middle 將元素的中線與父元素的基線加上x(chóng)一半的高度對(duì)齊
sub 將元素置于基線下方合適的位置
super 將元素置于基線上方合適的位置
text-top 將元素的頂部與父元素正文區(qū)域的頂部對(duì)齊
text-bottom 將元素的底部與父元素的正文區(qū)域的底部對(duì)齊
top 將元素的頂部與line box頂部對(duì)齊
bottom 將元素的底部與line box底部對(duì)齊
< percentage > 基于基線上(正值)下(負(fù)值)移動(dòng)元素,值通過(guò)百分比乘上行高而得
< length > 基于基線上(正值)下(負(fù)值)移動(dòng)元素

這里有兩個(gè)概念:基線(baseline)和正文區(qū)域(content area)。

先來(lái)感受下,舉個(gè)栗子:

http://jsfiddle.net/leozdgao/y4oexshn/6/embedded/result,html,css/

在第一個(gè)栗子中,直觀地展示了vertical-align屬性所有可取屬性的表現(xiàn)。

在第二個(gè)栗子中,藍(lán)色的線表示的就是基線(記得小時(shí)候英語(yǔ)練習(xí)本每行的第三根線么),綠色的輪廓表示的就是正文區(qū)域,這里故意加了個(gè)較大的行高,于是紅色的輪廓表示的就是line box的輪廓了。

對(duì)于有正文的行內(nèi)元素而言,它的基線正如上面的栗子中所展示的那樣,那么對(duì)于沒(méi)有正文的行內(nèi)元素(這里指的是有大小的inline-block元素但沒(méi)有正文或者類(lèi)似與img video這樣的replaced element),它們的基線位于它們margin box的底部。

我們發(fā)現(xiàn)在這些可取的值中,大部分都與它們的父元素(通常為line box)的基線有關(guān),那么line box的基線在哪里?或者栗子里的藍(lán)線是根據(jù)什么畫(huà)出來(lái)的?在W3C Spec中是這樣說(shuō)的:

  

CSS 2.1 does not define the position of the line box"s baseline

是的,沒(méi)有定義......不過(guò)好在瀏覽器之間的實(shí)現(xiàn)似乎沒(méi)有什么區(qū)別,取的就是正常的一個(gè)文本的基線位置,這里就不再多糾結(jié)line box的基線是怎么計(jì)算的了。

這里額外說(shuō)明下vertical-align: middle,根據(jù)上面的解釋,什么是父元素的基線加上x(chóng)一半的高度?還是來(lái)看個(gè)直觀的栗子:

http://jsfiddle.net/leozdgao/hf3ocgd8/2/embedded/result,html,css/

藍(lán)色的線依然表示基線,橙色的線表示的就是所謂的line box的基線加上x(chóng)一半高度的位置。同時(shí)也展示了為什么僅給元素設(shè)置vertical-align: middle是沒(méi)有辦法達(dá)到效果的。

不過(guò)line box的基線并不是固定不動(dòng)的,這次用一個(gè)實(shí)際的栗子來(lái)解釋,比如在單行中有一張圖片和一段文本,我們的需求是讓文字垂直居中對(duì)齊:(我用一個(gè)inline-block的方塊來(lái)模擬一張圖片)

http://jsfiddle.net/leozdgao/pe8t1LLf/1/embedded/result,html,css/

第一個(gè)case是沒(méi)有設(shè)置vertical-align時(shí)的樣子,我們現(xiàn)在知道將文字部分設(shè)置vertical-align: middle是不正確的。在第二個(gè)case展示了在圖片上應(yīng)用vertical-align: middle,我們發(fā)現(xiàn),為了滿足圖片中線與line box基線加上半個(gè)x高度的位置對(duì)齊,而圖片位置不能移動(dòng)了(整個(gè)line box就是它撐起來(lái)的),所以line box的基線被調(diào)整了。那么現(xiàn)在看上去好像是居中了?其實(shí)還是差一點(diǎn),如case3中那樣,這時(shí)將vertical-align: middle應(yīng)用與文本上,就可以垂直居中了。

由此我們得到的結(jié)論是:對(duì)于那些直接影響著line box高度的行內(nèi)元素來(lái)說(shuō),vertical-align對(duì)元素本身可能無(wú)影響,但會(huì)調(diào)整line box的基線。

垂直居中的若干種方法

垂直居中的需求往往并不限于單行文本,可能會(huì)設(shè)計(jì)多行文本,或者多行文本配圖片等等,下面整理的各種垂直居中的方案,并試著分析其優(yōu)劣。

方法一:

line-height設(shè)置為和height一樣高,常用于導(dǎo)航欄或者標(biāo)簽頁(yè)這樣的單行文本居中,缺點(diǎn)是這種方法只能用于單行文本,如果還涉及到圖片,可以根據(jù)上面一部分中提到的方法調(diào)整。

http://jsfiddle.net/leozdgao/150et323/embedded/result,html,css/

方法二:

利用css table,設(shè)置元素table結(jié)構(gòu),并應(yīng)用vertical-align: middle實(shí)現(xiàn)垂直居中,這種方法的實(shí)現(xiàn)可用于多行文本,要求IE8及以上版本。

http://jsfiddle.net/leozdgao/00dgdbem/embedded/result,html,css/

?方法三:

上下設(shè)置等高的padding或者margin值,個(gè)人覺(jué)得最笨的一種方法,唯一的優(yōu)點(diǎn)是兼容所有瀏覽器,缺點(diǎn)是很不靈活,大小需要額外計(jì)算并寫(xiě)死。(不提供栗子)

方法四:

絕對(duì)定位,這種方法并不僅限于『居中』,一種是利用負(fù)的margin值來(lái)實(shí)現(xiàn),另一種是用CSS3的translate來(lái)實(shí)現(xiàn),優(yōu)點(diǎn)的話同樣是可以支持多行文本,只是負(fù)的margin會(huì)寫(xiě)死大小,僅適合與大小固定的元素,用translate要考慮css3的瀏覽器兼容問(wèn)題,最大的局限性是絕對(duì)定位本身導(dǎo)致元素脫離文本流normal flow,多數(shù)情況下其父元素僅包括它一個(gè)子元素時(shí)會(huì)使用。

http://jsfiddle.net/leozdgao/h34zqLf2/1/embedded/result,html,css/

補(bǔ)充:支持CSS3的瀏覽器,也可以使用calc,像這樣使用:

csstop: calc(50% - (300px / 2));

方法五:

同樣是絕對(duì)定位,這個(gè)方法一般被稱為Stretching,把4個(gè)定位方向全部設(shè)置為0,這種方式不會(huì)將大小寫(xiě)死,瀏覽器兼容性也很不錯(cuò),但絕對(duì)定位的弊端上面也已經(jīng)提到過(guò)了。

http://jsfiddle.net/leozdgao/5a9z676h/1/embedded/result,html,css/

這里簡(jiǎn)單解釋下實(shí)現(xiàn)原理:我們發(fā)現(xiàn)了margin: auto,是的,我們給4個(gè)方向全部設(shè)置為0,即為元素提供了與其父元素相同的外邊緣。接下來(lái)看W3C Spec中提到的:

  

If none of the three are "auto": If both "margin-top" and "margin-bottom" are "auto", solve the equation under the extra constraint that the two margins get equal values.

這是就垂直方向而言的:其中的three指的是top height bottom,就是margin值的計(jì)算結(jié)果會(huì)讓元素盡可能居中。水平方向同理。

方法六:

隱藏一個(gè)浮動(dòng)元素,這個(gè)浮動(dòng)元素占父元素一半的高度,然后需要垂直居中的元素設(shè)置清除浮動(dòng),并設(shè)置大小為其高度一半的負(fù)margin-top,這個(gè)方法兼容任何瀏覽器,但總感覺(jué)有點(diǎn)hack的意味,不推薦。

http://jsfiddle.net/leozdgao/zoft69ao/1/embedded/result,html,css/

方法七:

FlexBox布局,瀏覽器需要支持,在移動(dòng)端可大肆使用。

http://jsfiddle.net/leozdgao/4my89br7/1/embedded/result,html,css/

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/111071.html

相關(guān)文章

  • vertical-align 和 line-height | 垂直居中

    摘要:垂直居中當(dāng)設(shè)置此時(shí)的頁(yè)面看似垂直居中,但是并沒(méi)有完全垂直居中。中線位置字符的中心并不是字符內(nèi)容的絕對(duì)居中位置。這種通過(guò)定高,元素垂直居中的方法不僅適用于現(xiàn)代瀏覽器,連瀏覽器也是支持的。 今天在寫(xiě)樣式時(shí),icon和文字都進(jìn)行了垂直居中的處理,但是icon并沒(méi)有垂直居中,后來(lái)發(fā)現(xiàn)由于 line-height 和 vertical 一起使用導(dǎo)致與預(yù)期樣式不同,特此對(duì) vertical-ali...

    ybak 評(píng)論0 收藏0
  • vertical-align以及利用 vertical-align 實(shí)現(xiàn)垂直居中

    摘要:在中實(shí)現(xiàn)垂直居中很多時(shí)候會(huì)用到,不過(guò)我一直對(duì)的使用糊里糊涂,現(xiàn)在整理一下關(guān)于它的一些知識(shí)點(diǎn)。將盒子的垂直中心點(diǎn)與父級(jí)盒子基線往上一半高度的位置對(duì)齊。時(shí)位置與設(shè)置一致。我們可以將設(shè)為來(lái)讓元素完全垂直居中。 在 css 中實(shí)現(xiàn)垂直居中很多時(shí)候會(huì)用到 vertical-align ,不過(guò)我一直對(duì) vertical-align 的使用糊里糊涂,現(xiàn)在整理一下關(guān)于它的一些知識(shí)點(diǎn)。原文鏈接 1. 適...

    lscho 評(píng)論0 收藏0
  • vertical-align以及利用 vertical-align 實(shí)現(xiàn)垂直居中

    摘要:在中實(shí)現(xiàn)垂直居中很多時(shí)候會(huì)用到,不過(guò)我一直對(duì)的使用糊里糊涂,現(xiàn)在整理一下關(guān)于它的一些知識(shí)點(diǎn)。將盒子的垂直中心點(diǎn)與父級(jí)盒子基線往上一半高度的位置對(duì)齊。時(shí)位置與設(shè)置一致。我們可以將設(shè)為來(lái)讓元素完全垂直居中。 在 css 中實(shí)現(xiàn)垂直居中很多時(shí)候會(huì)用到 vertical-align ,不過(guò)我一直對(duì) vertical-align 的使用糊里糊涂,現(xiàn)在整理一下關(guān)于它的一些知識(shí)點(diǎn)。原文鏈接 1. 適...

    madthumb 評(píng)論0 收藏0
  • CSS元素垂直居中【內(nèi)含vertical-align line-height 屬性詳解】

    摘要:所以文字最終可以在整個(gè)中垂直居中顯示。默認(rèn)值為,即把元素放在父元素的基線上。萬(wàn)萬(wàn)沒(méi)想到用兩行代碼就實(shí)現(xiàn)了只要給容器加上下面兩條樣式,就成功垂直居中了,都是多余了的。 請(qǐng)一定看到最后,flex太令人驚喜! ヾ(o???)? 入個(gè)門(mén) 先來(lái)考慮這樣一個(gè)問(wèn)題:一行文字在一個(gè)固定高度的父div中怎樣做到垂直居中?我們都知道設(shè)置父div的line-height 等于它的height就可以了,像下面...

    frontoldman 評(píng)論0 收藏0
  • CSS元素垂直居中【內(nèi)含vertical-align line-height 屬性詳解】

    摘要:所以文字最終可以在整個(gè)中垂直居中顯示。默認(rèn)值為,即把元素放在父元素的基線上。萬(wàn)萬(wàn)沒(méi)想到用兩行代碼就實(shí)現(xiàn)了只要給容器加上下面兩條樣式,就成功垂直居中了,都是多余了的。 請(qǐng)一定看到最后,flex太令人驚喜! ヾ(o???)? 入個(gè)門(mén) 先來(lái)考慮這樣一個(gè)問(wèn)題:一行文字在一個(gè)固定高度的父div中怎樣做到垂直居中?我們都知道設(shè)置父div的line-height 等于它的height就可以了,像下面...

    Sanchi 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<