模型概覽
flex是一種頁面佈局方式,被叫做伸縮模型,它可以輕易的實現等分、垂直居中、水平居中、自動伸縮等,用盒模型做起來很麻煩的佈局。
採用flex佈局實現方法:
// html
<div class="parent">
<div class="child">1</div>
<div class="child">2</div>
...
</div>
// css
.parent {
display: flex; // 塊元素
display: inline-flex; // 內聯元素
}
複製程式碼
採用flex佈局的元素被稱為flex容器,上面的div元素就是flex容器,容器中的子元素自動成為容器成員,被稱為flex專案。
flex容器預設有兩根軸,水平方向的主軸,垂直方向的交叉軸。
容器的屬性
flex-direction // 主軸方向
flxe-wrap // 在軸上排列的方式
flex-flow // flex-direction和flex-wrap的簡寫
justify-content // 主軸上如何對齊
align-items // 交叉軸上如何對齊
align-content // 多根主軸上如何對齊
複製程式碼
flex-direction
定義主軸方向
flex-direction: row | row-reverse | column | column-reverse 可能的四個值
複製程式碼
row(預設) 主軸水平,正方向為右
data:image/s3,"s3://crabby-images/7022c/7022c2b4f64356fa59fd5cc1897b6d8828da1699" alt="CpMec4.png"
data:image/s3,"s3://crabby-images/765e2/765e25690bdde75c8e1d7eb9091e1ad214dbff3e" alt="CpMV9U.png"
data:image/s3,"s3://crabby-images/52ee6/52ee61ab5f02973cec7133de58673a65ace7c69e" alt="CpMZ3F.png"
data:image/s3,"s3://crabby-images/4b397/4b397145881fe9552f4e0c2b799151400e0efcfb" alt="CpMAhT.png"
flex-wrap
定義主軸上的專案是否還行
flex-wrap: nowrap | wrap | wrap-reverse
複製程式碼
nowrap(預設) 不換行,如果子專案跨度大於父容器,子專案會等比縮小以被容納,除非子專案裡有flex: none
,這樣子專案會溢位父容器。
data:image/s3,"s3://crabby-images/7022c/7022c2b4f64356fa59fd5cc1897b6d8828da1699" alt="CpMec4.png"
data:image/s3,"s3://crabby-images/d0255/d0255772ebc0b855a9a878f4d97e052eee945c28" alt="CpMD4f.png"
data:image/s3,"s3://crabby-images/48f6f/48f6f1b4366ceff99fc8fd40ed1330682080450e" alt="CpMsC8.png"
flex-flow
flex-direction和flex-wrap的簡寫
flex-flow: <flex-direction> || <flex-wrap>;
複製程式碼
預設 row nowrow
justify-content
定義主軸上的專案的分佈方式
justify-content: flex-start | center | flex-end | space-between | space-around
複製程式碼
flex-start(預設) 與主軸起點對齊
data:image/s3,"s3://crabby-images/2eeb9/2eeb96bc831b1b89b9c9d12de32d9ce959447795" alt="CplfhV.png"
data:image/s3,"s3://crabby-images/10693/106933e56f1c507c954e9c416a69bc75336dc44d" alt="CplRkq.png"
data:image/s3,"s3://crabby-images/01a97/01a977cc125a1d13eea810cf9daa46e10170f995" alt="Cpl4pT.png"
data:image/s3,"s3://crabby-images/0d3e2/0d3e2bfa2deca1a70bf7402e83c8304b65e83baf" alt="Cplc0s.png"
data:image/s3,"s3://crabby-images/23405/234054fedfc22def431bc56a004e4e9133c30ca3" alt="Cplg7n.png"
align-items
定義專案在交叉軸上的分佈
align-items: flex-start | center | flex-end | baseline | stretch
複製程式碼
flex-start(預設) 與交叉軸起點對齊
data:image/s3,"s3://crabby-images/41280/41280a3cc8b2d5922ca14aa83b9c44e6cad3f418" alt="Cp1728.png"
data:image/s3,"s3://crabby-images/27dc9/27dc9590616fed55f0ce126a87618ecc3f1ef859" alt="Cp1T8f.png"
data:image/s3,"s3://crabby-images/d911b/d911b8690e824b32ff214a7e3d63ae578f4b4cf7" alt="Cp155t.png"
data:image/s3,"s3://crabby-images/fa8e9/fa8e98ca5be4deb351e2de6fa586f5b92c7aea21" alt="Cp1oPP.png"
data:image/s3,"s3://crabby-images/f7dad/f7dadb36e1236ab072a10f0ea7cee8fb082344ef" alt="Cp14UI.png"
align-content
定義多根主軸線的對齊方式,如果只有一根主軸該屬性不起作用。
align-content: flex-start | center | flex-end | space-between | space-around | stretch
複製程式碼
flex-start 與交叉軸頂端對齊
data:image/s3,"s3://crabby-images/946e7/946e7ca1c3c19895967ae5333f53cd824f992562" alt="CpGkNR.png"
data:image/s3,"s3://crabby-images/eb50a/eb50a11b37bd1f679cdca5a834f9c13c2055ec1a" alt="CpGFE9.png"
data:image/s3,"s3://crabby-images/5c3e3/5c3e3411cc29ba7ed8b1b5e54d387bc0bc6b2933" alt="CpGegK.png"
data:image/s3,"s3://crabby-images/f51cf/f51cfea62c3097b16f1e0a90fffd82fddca82482" alt="CpGV9x.png"
data:image/s3,"s3://crabby-images/a867a/a867ac66754d3be384811f9562d0531bc08d9578" alt="CpGA41.png"
data:image/s3,"s3://crabby-images/00062/00062239c99d57ebe9f87e9453c2ce2b0d13c3de" alt="CpGZ36.png"
專案的屬性
前面說的屬性都是設定在容器上的,下面就說一說專案上的屬性
order // 設定專案的排列順序
flex-grow // 專案的放大
flex-shrink // 專案的縮小
flex-basis // 專案的基礎大小
flex // flex-basis,flex-grow,flex-shrink的簡寫
align-self // 設定單個專案在交叉軸上的分佈
複製程式碼
// html
<div class="parent">
<div class="child">1</div>
<div class="child">2</div>
...
</div>
// css
.parent {
display: flex;
}
.child: {
order: ...;
flex: ...;
align-self: ...;
}
複製程式碼
order
定義專案的排列順序,數值越小,排列越靠前,預設為0。
order: <integer>
複製程式碼
如果order屬性相同,則按照專案的先後順序排列,若專案沒有order,則去預設值0
// html
<div class="parent">
<div class=child1></div>
<div class=child2></div>
<div class=child3></div>
<div class=child4></div>
</div>
// css
...
.parent {
display: flex;
}
.child1 {
order: 4;
background-color: red;
}
.child2 {
background-color: yellow;
}
.child3 {
order: 0;
background-color: blue;
}
.child4 {
order: -1;
background-color: green;
}
複製程式碼
data:image/s3,"s3://crabby-images/8e184/8e184be636875a8c6916d05f37c9ed79f940eb8f" alt="flex快速學習"
flex-grow
定義專案的放大比例,當容器空間大於專案總大小時,專案就會按照比例分割多餘容器空間使自己放大,預設為0,就是即使有多餘空間也不會放大。負值無效。
flex-grow: <number>
複製程式碼
沒有flex-grow
data:image/s3,"s3://crabby-images/aa41a/aa41a1b706f281cfad5672b3532e96d8a29078fa" alt="flex快速學習"
flex-grow: 1
data:image/s3,"s3://crabby-images/54dc3/54dc331106a535ac89f41bf7f43126153a0cf0da" alt="flex快速學習"
flex-grow: 1
第二個專案flex-grow: 2
data:image/s3,"s3://crabby-images/d8840/d88404d2ed72622c71b4aef263d0ee97f7beb5d2" alt="flex快速學習"
flex-shrink
定義專案的縮小比例,當容器空間小於專案總大小時,專案就會根據按比例縮小自身以便容器可以容納專案。預設為1,就是預設會在空間不足時縮小專案。負值無效。
flex-shrink: <number>
複製程式碼
flex-shrink: 0
專案超出部分會溢位
data:image/s3,"s3://crabby-images/ecb50/ecb50ed7df59da0bc32f7098009d41558d48446d" alt="flex快速學習"
flex-shrink: 1
(預設),專案等比縮小
data:image/s3,"s3://crabby-images/0ade1/0ade1ab47bcbd719d43412c55b0fc8d9b2c874a1" alt="flex快速學習"
flex-shrink: 2
,其它flex-shrink: 1
,第二個專案縮小量是其它專案的2倍
data:image/s3,"s3://crabby-images/f179e/f179e97f74cbc58ec199e710c397cbfc63459fda" alt="flex快速學習"
flex-basis
定義專案在縮放之前的大小,預設值auto,即本來的大小。
flex-basis: <length> | auto
複製程式碼
可以設定為根width和height屬性一樣的值。
flex
flex-grow,flex-shrink,flex-basis的簡寫形式。預設值0 1 auto。
該屬性有兩個快捷值,flex: auto
即flex: 1 1 auto
,flex: none
即flex: 0 0 auto
align-self
align-self屬性允許單個專案有與其他專案不一樣的對齊方式,可覆蓋align-items屬性。預設值為auto,表示繼承父元素的align-items屬性,如果沒有父元素,則等同於stretch。
align-self: auto | flex-start | flex-end | center | baseline | stretch;
複製程式碼
除了auto,其餘值都跟align-items
表現形式一樣。
align-self: align-end
專案與交叉軸末尾對齊
data:image/s3,"s3://crabby-images/70548/70548663f73e5e69d85a1b6559e782615745d01f" alt="flex快速學習"