flex佈局

Flex是Flexible Box的縮寫,意爲"彈性佈局",用來爲盒狀模型提供最大的靈活性。css

任何一個容器均可以指定爲Flex佈局。瀏覽器

 

容器默認存在兩根軸:水平的主軸和垂直的交叉軸佈局

容器的屬性

  • flex-direction
  • flex-wrap
  • flex-flow
  • justify-content
  • align-items
  • align-content

   1.flex-direction屬性flex

      屬性決定主軸的方向(即項目的排列方向)spa

        row(默認值):主軸爲水平方向,起點在左端。code

        row-reverse:主軸爲水平方向,起點在右端。繼承

        column:主軸爲垂直方向,起點在上沿。token

        column-reverse:主軸爲垂直方向,起點在下沿。string

   2. flex-wrap屬性

      默認狀況下,項目都排在一條線(又稱"軸線")上。flex-wrap屬性定義,若是一條軸線排不下,如何換行it

        nowrap(默認):不換行。

        wrap:換行,第一行在上方。

        wrap-reverse:換行,第一行在下方。

   3.  flex-flow屬性

      flex-flow屬性是flex-direction屬性和flex-wrap屬性的簡寫形式,默認值爲row nowrap

    4. justify-content屬性

      justify-content屬性定義了項目在主軸上的對齊方式。

        flex-start(默認值):左對齊

        flex-end:右對齊

        center: 居中

        space-between:兩端對齊,項目之間的間隔都相等。

        space-around:每一個項目兩側的間隔相等。因此,項目之間的間隔比項目與邊框的間隔大一倍。

  

    5.align-items屬性

      align-items屬性定義項目在交叉軸上如何對齊。

        flex-start:交叉軸的起點對齊。

        flex-end:交叉軸的終點對齊。

        center:交叉軸的中點對齊。

        baseline: 項目的第一行文字的基線對齊。

        stretch(默認值):若是項目未設置高度或設爲auto,將佔滿整個容器的高度

 

   6. align-content屬性

      align-content屬性定義了多根軸線的對齊方式。若是項目只有一根軸線,該屬性不起做用。

        flex-start:與交叉軸的起點對齊。

        flex-end:與交叉軸的終點對齊。

        center:與交叉軸的中點對齊。

        space-between:與交叉軸兩端對齊,軸線之間的間隔平均分佈。

        space-around:每根軸線兩側的間隔都相等。因此,軸線之間的間隔比軸線與邊框的間隔大一倍。

        stretch(默認值):軸線佔滿整個交叉軸。

項目的屬性

  • order
  • flex-grow
  • flex-shrink
  • flex-basis
  • flex
  • align-self

    

  1.order屬性

      order屬性定義項目的排列順序。數值越小,排列越靠前,默認爲0。

      .item {          order: <integer>;       }

  2.flex-grow屬性

      flex-grow屬性定義項目的放大比例,默認爲0,即若是存在剩餘空間,也不放大。

      .item {          flex-grow: <number>; /* default 0 */       }

  3.flex-shrink屬性

      flex-shrink屬性定義了項目的縮小比例,默認爲1,即若是空間不足,該項目將縮小。  

      .item {          flex-shrink: <number>; /* default 1 */       }

   4.flex-basis屬性

      flex-basis屬性定義了在分配多餘空間以前,項目佔據的主軸空間(main size)。

      瀏覽器根據這個屬性,計算主軸是否有多餘空間。它的默認值爲auto,即項目的原本大小。

      .item {          flex-basis: <length> | auto; /* default auto */       }

  5.flex屬性

      flex屬性是flex-growflex-shrink 和 flex-basis的簡寫,默認值爲0 1 auto。後兩個屬性可選。   

      .item {          flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]       }

  6.align-self屬性

      align-self屬性容許單個項目有與其餘項目不同的對齊方式,可覆蓋align-items屬性。默認值爲auto,表示繼承父元素的align-items屬性,

      若是沒有父元素,則等同於stretch

      .item {          align-self: auto | flex-start | flex-end | center | baseline | stretch;       }
相關文章
相關標籤/搜索