<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        我對Flexbox布局模式的理解_html/css_WEB-ITnose

        來源:懂視網 責編:小采 時間:2020-11-27 16:41:01
        文檔

        我對Flexbox布局模式的理解_html/css_WEB-ITnose

        我對Flexbox布局模式的理解_html/css_WEB-ITnose:Flexbox,一種CSS3的布局模式,也叫做彈性盒子模型,用來為盒裝模型提供最大的靈活性。首先舉一個栗子,之前我們是這樣實現一個div盒子水平垂直居中的。在知道對象高寬的情況下,對居中元素絕對百分比定位,然后通過margin偏移的方式來實現。 .cont
        推薦度:
        導讀我對Flexbox布局模式的理解_html/css_WEB-ITnose:Flexbox,一種CSS3的布局模式,也叫做彈性盒子模型,用來為盒裝模型提供最大的靈活性。首先舉一個栗子,之前我們是這樣實現一個div盒子水平垂直居中的。在知道對象高寬的情況下,對居中元素絕對百分比定位,然后通過margin偏移的方式來實現。 .cont

        Flexbox,一種CSS3的布局模式,也叫做彈性盒子模型,用來為盒裝模型提供最大的靈活性。首先舉一個栗子,之前我們是這樣實現一個div盒子水平垂直居中的。在知道對象高寬的情況下,對居中元素絕對百分比定位,然后通過margin偏移的方式來實現。

         

        假如使用了flex后,實現起來就簡單了,而且不需要自己去算,也不需要絕對定位,只需要通過對伸縮容器定義兩個屬性,justify-content定義伸縮項目沿著主軸線的對齊方式為center, align-items定義伸縮項目在側軸(垂直于主軸)的對齊方式為center,具體如下:

         

        其實Flexbox的優秀特性并不是這一些,首先來一張它的屬性圖吧~

        首先我們來分析下這一張圖,從第一個子節點可以看到Flexbox由Flex容器和Flex項目組成,容器即父元素,項目即子元素。他們之間的一些關系可以這樣來表示:

        這張圖可以在接下來的屬性分析中用到。

        Flex容器

        display:flex

        當我們使用flexbox布局時候,需要先給父容器的display值定位flex(塊級)或者inline-flex(行內級)。

        當使用了這個值以后,伸縮容器會為內容建立新的伸縮格式化上下文(FFC),它的上下文展示效果和BFC根元素相同(BFC特性:浮動不會闖入伸縮容器,且伸縮容器的邊界不會與其內容邊界疊加)。

        伸縮容器不是塊容器,因此有些設計用來控制塊布局的屬性,在伸縮布局中不適用,特別是多欄(column),float,clear,vertical-align這些屬性。

        flex-direction

        [flex-direction]屬性用來控制上圖中伸縮容器中主軸的方向,同時也決定了伸縮項目的方向。

      1. flex-direction:row;也是默認值,即主軸的方向和正常的方向一樣,從左到右排列。
      2. flex-direction:row-reverse;和row的方向相反,從右到左排列。
      3. flex-direction:column;從上到下排列。
      4. flex-direction:column-reverse;從下到上排列。 以上只針對ltr書寫方式,對于rtl正好相反了。
      5. 網頁展示效果如下:

        flex-warp

        [flex-wrap]屬性控制伸縮容器是單行還是多行,也決定了側軸方向(新的一行的堆放方向)。

      6. flex-wrap:nowrap;伸縮容器單行顯示,默認值;
      7. flex-wrap:wrap;伸縮容器多行顯示;伸縮項目每一行的排列順序由上到下依次。
      8. flex-wrap:wrap-reverse;伸縮容器多行顯示,但是伸縮項目每一行的排列順序由下到上依次排列。
      9. 網頁效果見圖;

        flex-flow

        [flex-flow]屬性為flex-direction(主軸方向)和flex-wrap(側軸方向)的縮寫,兩個屬性決定了伸縮容器的主軸與側軸。

      10. flex-flow:[flex-direction][flex-wrap];默認值為row nowrap;
      11. 舉兩個栗子:

      12. flex-flow:row;也是默認值;主軸是行內方向,單行顯示,不換行;
      13. flex-flow:row-reverse wrap;主軸和行內方向相反,從右到左,項目每一行由上到下排列(側軸)。
      14. 網頁效果如下:

        這里大家可以多自己去試試不同的組合。

        justify-content

        [justify-content]用于定義伸縮項目在主軸上面的的對齊方式,當一行上的所有伸縮項目都不能伸縮或可伸縮但是已經達到其最大長度時,這一屬性才會對多余的空間進行分配。當項目溢出某一行時,這一屬性也會在項目的對齊上施加一些控制。

      15. justify-content:flex-start;伸縮項目向主軸的起始位置開始對齊,后面的每元素緊挨著前一個元素對齊。
      16. justify-content:flex-end;伸縮項目向主軸的結束位置對齊,前面的每一個元素緊挨著后一個元素對齊。
      17. justify-content:center;伸縮項目相互對齊并在主軸上面處于居中,并且第一個元素到主軸起點的距離等于最后一個元素到主軸終點的位置。以上3中都是“捆綁”在一個分別靠左、靠右、居中對齊。
      18. justify-content:space-between;伸縮項目平均的分配在主軸上面,并且第一個元素和主軸的起點緊挨,最后一個元素和主軸上終點緊挨,中間剩下的伸縮項目在確保兩兩間隔相等的情況下進行平分。
      19. justify-content:space-around;伸縮項目平均的分布在主軸上面,并且第一個元素到主軸起點距離和最后一個元素到主軸終點的距離相等,且等于中間元素兩兩的間距的一半。完美的平均分配,這個布局在阿里系中很常見。
      20. 還是看demo理解起來快一點:

        align-items

        [align-items]用來定義伸縮項目在側軸的對齊方式,這類似于[justify-content]屬性,但是是另一個方向。(flex-directon和flex-wrap是一對,justify-content和align-items是一對,前者分別定義主軸和側軸的方向,后者分別定義主軸和側軸中項目的對齊方式)。

      21. align-items:flex-start;伸縮項目在側軸起點邊的外邊距緊靠住該行在側軸起點的邊。
      22. align-items:flex-end;伸縮項目在側軸終點邊的外邊距靠住該行在側軸終點的邊。
      23. align-items:center;伸縮項目的外邊距在側軸上居中放置。
      24. align-items:baseline;如果伸縮項目的行內軸與側軸為同一條,則該值與[flex-start]等效。 其它情況下,該值將參與基線對齊。
      25. align-items:stretch;伸縮項目拉伸填充整個伸縮容器。此值會使項目的外邊距盒的尺寸在遵照「min/max-width/height」屬性的限制下盡可能接近所在行的尺寸。
      26. 下面demo只展示center和stretch的栗子,其他幾個可以參考flex-start和flex-end那樣。

        align-content

        [align-content]屬性可以用來調準伸縮行在伸縮容器里的對齊方式,這與調準伸縮項目在主軸上對齊方式的[justify-content]屬性類似。只不過這里元素是以一行為單位。請注意本屬性在只有一行的伸縮容器上沒有效果。當使用flex-wrap:wrap時候多行效果就出來了。

        align-content: flex-start || flex-end || center || space-between || space-around || stretch;

      27. align-content: stretch;默認值,各行將會伸展以占用剩余的空間。
      28. 其他可以參考[justify-content]用法。
      29. 具體圖片來至w3.org官方文檔;

        太麻煩。寫不下去了,摔。

        Flex項目

        終于寫到關于伸縮項目的相關屬性了,主要是3個,order,flex(flex-grow,flex-shrink,flex-basis的組合),align-self;用來比較多的是前兩個。

        order

        有一種用法比較多,想設置一組中有兩個元素一個排第一,另外一個排最后,主需要將第一個的order:-1;另一個為order:0;這樣就好了。

        譬如我們想控制一個container中有4個box,想box4為一個顯示,box1為最后一個顯示。只需要 這樣

         1 2 3 4

        顯示效果就這樣了:

        flex

        [flex]屬性可以用來指定可伸縮長度的部件,是flex-grow(擴展比例),flow-shrink(收縮比例),flex-basis(伸縮基準值)這個三個屬性的縮寫寫法,建議大家采用縮寫的方式而不是單獨來使用這3個屬性。

        flex:none | [ <'flex-grow'> ?<'flew-shrink'> || <'flow-basis'>]// flex-grow是必須得flex-shrink和flow-basis是可選的

      30. flex-grow:;其中number作為擴展比例,沒有單位,初始值是0,主要用來決定伸縮容器剩余空間按比例應擴展多少空間。
      31. flex-grow:;其中number作為收縮比例,沒有單位,初始值是1,也就是剩余空間是負值的時候此伸縮項目相對于伸縮容器里其他伸縮項目能收縮的空間比例,在收縮的時候收縮比率會以[flex-basis]伸縮基準值加權。
      32. flex-basis:|auto;默認是auto也就是根據可伸縮比率計算出剩余空間的分布之前,伸縮項目主軸長度的起始數值。若在「flex」縮寫省略了此部件,則「flex-basis」的指定值是長度零。
      33. flex-basis用圖來表示就是這樣:

        align-self

        [align-self]用來在單獨的伸縮項目上覆寫默認的對齊方式,這個屬性是用來覆蓋伸縮容器屬性align-items對每一行的對齊方式。也就是說在默認的情況下這兩個值是相等的。

        align-self: auto | flex-start | flex-end | center | baseline | stretch

        我的看法

        講了這么多他們的使用,我們來看一看flexbox布局的兼容性。

        具體大家可以見這個網站:caniuse

        在PC端其實很樂觀了,基本上主流的瀏覽器都已經兼容了flex的使用,但是到了移動端就不是那么好了,特別是國內瀏覽器,考慮到uc瀏覽器占了大頭,但是uc從圖中看到只兼容flex最老的一個版本,也就是2009年的版本,即display:box;很多現在flex的優秀特性到了它上面都不兼容了,所以建議大家在使用的時候,假如2009版本可以滿足開發要求的話,還是去使用2009版本,這樣風險更小。

        但是假如想兼容多個瀏覽器,可以采用優雅降級的方式來使用,這里推薦一個scss的sass-flex-mixin,這樣就可以使用最新的寫法,并且兼容大部分瀏覽器了。

        相信flexbox布局在以后的移動端會用得越來越多的。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        我對Flexbox布局模式的理解_html/css_WEB-ITnose

        我對Flexbox布局模式的理解_html/css_WEB-ITnose:Flexbox,一種CSS3的布局模式,也叫做彈性盒子模型,用來為盒裝模型提供最大的靈活性。首先舉一個栗子,之前我們是這樣實現一個div盒子水平垂直居中的。在知道對象高寬的情況下,對居中元素絕對百分比定位,然后通過margin偏移的方式來實現。 .cont
        推薦度:
        標簽: flex it html
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产在线精品免费aaa片| 免费人成视频在线播放| 亚洲精品~无码抽插| www免费黄色网| 亚洲欧洲日产国码无码久久99| 久久久久se色偷偷亚洲精品av | 无码A级毛片免费视频内谢| 亚洲线精品一区二区三区影音先锋 | 久久精品无码一区二区三区免费 | 国产国产人免费人成免费视频| 2020年亚洲天天爽天天噜| 国产成人精品免费视频大全| 浮力影院亚洲国产第一页| 亚洲色大18成人网站WWW在线播放| 又粗又大又黑又长的免费视频 | 国产l精品国产亚洲区在线观看| 永久免费av无码网站yy| 亚洲明星合成图综合区在线| 日本免费网址大全在线观看 | 花蝴蝶免费视频在线观看高清版 | A国产一区二区免费入口| 亚洲av成人无码久久精品| www成人免费观看网站| 亚洲精品国精品久久99热一| 99视频在线看观免费| 中文字幕亚洲综合小综合在线| 香蕉视频在线观看免费国产婷婷| 国产亚洲美女精品久久久久| 亚洲综合伊人久久综合| 最近中文字幕电影大全免费版 | 在线免费观看h片| 亚洲A∨精品一区二区三区| 色偷偷亚洲女人天堂观看欧| 免费va在线观看| 国内精品久久久久影院亚洲| 免费人成视频在线观看不卡| 日韩免费无码一区二区三区 | 亚洲福利在线视频| 最好免费观看韩国+日本| 91在线免费视频| 亚洲中文字幕无码中文|