一塊兒從頭學習Flex

前言

「其實我以爲flex很像如今的人——是適應性很好的生物,在家秋衣秋褲在外香肩外露。flex container看做一個環境或者大佬,flex-item是其中個體或者馬仔。個體如何存在很大程度上取決環境的設定,固然也會有一些出世的人 好比position: absolute; 存在感就有比較酷」 —— 燉燉css

背景:佈局模式

頁面拆開了看,無非是由衆多尺寸各異的box以不一樣層疊水平和順序組合而成。html

CSS2.1定義了下面前4種佈局模式,不一樣的佈局模式下box內的渲染規則不一樣。css3

佈局 特性
block layout 塊級佈局 獨立的渲染區域,與外界無關
inline layout 行內佈局 爲佈局文本設計
table layout 表格佈局 在表格格子布局二維數據
positioned layout 定位佈局 不考慮文件流中其餘元素,佈局有很是明確的位置
flex layout 彈性佈局 呈現複雜的應用與頁面

flex-layout和block-layout很是類似。git

塊級佈局中一些比較複雜的屬性,好比浮動、多列,在彈性佈局中是沒有的;github

反過來彈性佈局有一些很簡單但厲害的屬性去實現複雜的網頁佈局中常見的需求。web

flex-container檔案

  1. 元素名:flex container
  2. 中文名:彈性容器、彈性盒
  3. 身份:大佬
  4. 年代:css3,chrome29就已經能夠不加前綴地支持了
  5. 權力:彈性佈局——指定容器中元素的佈局方式,子元素在其中是否收縮或伸展
  6. 被接受程度:全部的瀏覽器都支持flexbox(caniuse
    chrome

    image
    image

    flex layout is split into three versions: 
     1. old version  display: box;
     2. transitional version: display:flexbox;
     3. present standard version: display:flex;
    
     Android
     2.3  began to support old version: display: -webkit-box;
     4.4 began to support standard version: display: flex;
    
     IOS
     6.1  began to support old version: display: -webkit-box;
     7.1 began to support standard version: display: flex;複製代碼
  7. 如何成爲大佬 flexdisplay:flex/inline-flex; 分別產生塊級和行內的彈性容器。瀏覽器

  8. 社會關係:彈性容器中的子元素——flex items
  9. 主要參數:主軸、側軸,主軸長度、側軸長度
    flexbox
    flexbox
  10. 速記幾個屬性:bash

    • flex-flow 子元素排列的方向和是否換行 flex-flow: [<flex-direction> <flex-wrap>]工具

      1. flex-direction 排列方向和順序(主軸側軸方向決定)

        flex-direction: row | row-reverse | column | column-reverse

      2. flex-wrap 主軸個數和排列順序

        flex-wrap: nowrap | wrap | wrap-reverse



        eg. flex-flow: row || column wrap || row-reverse wrap-reverse

    • justify-content 安排(決定)子元素在主軸上如何分配空白空間的方式

      justify-content: flex-start | flex-end | center | space-between | space-around

    • align-items 安排(決定)子元素在縱軸上的伸展方式

      align-items: flex-start | flex-end | center | baseline | stretch

    • align-content 多條主軸如何在縱軸方向上面排布,跟justify-content 在主軸方向對齊元素的方式類似,若是隻有一行該屬性不生效

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

flex-items檔案

  1. 元素名:flex item
  2. 中文名:彈性子元素
  3. 身份:flex container的馬仔
  4. 如何成爲馬仔 flex-item:在flex container裏面的子元素自動成爲flex item,直接包含在容器中的連續文本會被包裹成一個匿名的flex item,空白的item不會被渲染出來
  5. 職責:爲其內容建立新的formatting context,flex item是flex-level的塊,因此使用彈性容器的彈性格式化上下文而不是BFC(好比在BFC中margin會坍塌在彈性格式化上下文中不會
  6. 比較酷的絕對定位的彈性子元素 特性速記
  7. 幾個重要屬性:

    • marginspaddings:flex item的margins不會重疊(應該儘可能避免使用百分比的margins、paddings,在不一樣瀏覽器下表現不同,目前在IE/FF/Chrome尚未測試出來差異啦) 百分比的基準是瀏覽器寬度

    • 有order的元素渲染順序會重置,至關於指定特定的子元素出如今什麼位置

    • visibility: collapse 看例子

    • flex 子元素的彈性

      flex: [ <flex-grow> <flex-shrink> <flex-basis>] 詳見flex縮寫探究

    • margin: auto 會「貪吃」掉全部空白的區域 例子

    • align-self 單獨設置子元素(包括絕對定位的子元素)在縱軸上的定位方式,能夠覆蓋align-items屬性

      align-self: auto | flex-start | flex-end | center | baseline | stretch (auto是跟container的flex-items屬性一致)

flex縮寫的探究

flex: [ <flex-grow> <flex-shrink> <flex-basis>]

  • flex-grow 默認1 如何分配container中的空白空間,數值決定權重
  • flex-shrink 默認1 在空間不夠的時候如何收縮元素
  • flex-basis 指定flex-item的默認尺寸 百分比以父級容器寬度爲基數計算(Flexbox Tester能夠幫助理解flex item寬度的工具網站)
縮寫 flex-grow flex-shrink flex-basis
no declaration 0 1 auto
auto 1 1 auto
0 0 1 0%
1 1 1 0%
none 0 0 auto

彈性佈局不是塊級佈局

  1. float不生效
  2. 相鄰子元素的margin不會發生重疊
  3. 多列布局column-*不起做用
  4. 'float'和'clear'對flex item不產生浮動或者清除浮動的效果,也不會讓它脫離文檔流
  5. vertical-align對於flex item沒效果
  6. 僞元素::first-line::first-letter不適用於彈性容器,彈性容器也不會成爲其父元素的first-line或者first-letter

爲何你的flexbox無論用

"瞭解一我的並不表明什麼,人是會變的"——《重慶森林》。
放在W3C規範和瀏覽器實現就是「瞭解一個屬性並不表明什麼,瀏覽器實現都是有差別的」。

W3C只是制定了規範,可是遵照程度和實現效果各個瀏覽器是有所差別的。當你清楚你想實現什麼效果而使用了對應的屬性卻發現不起做用,那麼極可能是瀏覽器的差別形成的。好比上面提到的flex縮寫,IE10的實現是不符合規範的

Declaration What it should mean What it means in IE 10
(no flex declaration) flex: 0 1 auto flex: 0 0 auto
flex: 1 flex: 1 1 0% flex: 1 0 0px
flex: auto flex: 1 1 auto flex: 1 0 auto
flex: initial flex: 0 1 auto flex: 0 0 auto

另一個可能不常見但也能體現瀏覽器差別的是,嵌套的彈性容器的baseline不做爲其餘彈性子元素的對齊參考(能夠在Firefox戳例子看看)。

「當你在構建頁面的時候使用了flexbox可是發現他並無出現你預想的效果,能夠在這裏找到答案」——flexbugs

關於flex.css

flex.css就是對flex佈局的一種封裝,經過簡潔的屬性設置就能使得它完美的運行在移動端的各類瀏覽器,甚至能運行在ie10+的各類PC端瀏覽器中。是一種相似於標籤屬性聲明的方式,指定flex屬性。

<!-- 設置主軸方向 -->
<div class="flexbox" flex="dir: top">   
    ...
</div>複製代碼
flex.css html css
dir: top flex-direction: cloumn
main: center justify-content: center
cross: top align-items: flex-start

試驗flex佈局的工具網站: flexbox playground and code generator

參考

  1. W3C flexbox
  2. flex.css快速入門,極速佈局
  3. flexbugs
  4. 使用彈性盒子進行高級佈局
  5. Flex 佈局教程:語法篇

by DDun

相關文章
相關標籤/搜索