課程思維導圖
Flex 彈性盒佈局
CSS3彈性盒佈局的理解:
web應用有不同裝置尺寸和解析度,這時需要響應式介面設計來滿足複雜的佈局需求,Flex彈性盒模型的優勢在於開發人員只是宣告佈局應該具有的行為,而不需要給出具體的實現方式,瀏覽器負責完成實際佈局。
當佈局涉及到不定寬度,分佈對齊的場景時,就要優先考慮彈性盒佈局。
容器的屬性
主軸的方向
flex-direction: row | row-reverse | column | column-reverse;
row(預設值):主軸為水平方向,起點在左端。
row-reverse:主軸為水平方向,起點在右端。
column:主軸為垂直方向,起點在上沿。
column-reverse:主軸為垂直方向,起點在下沿。
複製程式碼
換行屬性
flex-wrap: nowrap | wrap | wrap-reverse;
nowrap(預設):不換行。
wrap:換行,第一行在上方。
wrap-reverse:換行,第一行在下方。
複製程式碼
簡寫:方向 + 換行
flex-flow: <flex-direction> || <flex-wrap>;
複製程式碼
主軸對齊方式
justify-content: flex-start | flex-end | center | space-between | space-around;
flex-start(預設值):左對齊
flex-end:右對齊
center: 居中
space-between:兩端對齊,專案之間的間隔都相等。
space-around:每個專案兩側的間隔相等。所以,專案之間的間隔比專案與邊框的間隔大一倍。
複製程式碼
交叉軸對齊方式
align-items: flex-start | flex-end | center | baseline | stretch;
flex-start:交叉軸的起點對齊。
flex-end:交叉軸的終點對齊。
center:交叉軸的中點對齊。
baseline: 專案的第一行文字的基線對齊。
stretch(預設值):如果專案未設定高度或設為auto,將佔滿整個容器的高度。
複製程式碼
多根軸線對齊方式
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
flex-start:與交叉軸的起點對齊。
flex-end:與交叉軸的終點對齊。
center:與交叉軸的中點對齊。
space-between:與交叉軸兩端對齊,軸線之間的間隔平均分佈。
space-around:每根軸線兩側的間隔都相等。所以,軸線之間的間隔比軸線與邊框的間隔大一倍。
stretch(預設值):軸線佔滿整個交叉軸。
複製程式碼
專案的屬性
排列順序,數值越小,排列越靠前,預設為0。
order: <integer>;
複製程式碼
專案的放大比例,預設為0,即如果存在剩餘空間,也不放大。
flex-grow: <number>; /* default 0 */
複製程式碼
專案的縮小比例,預設為1,即如果空間不足,該專案將縮小。
flex-shrink: <number>; /* default 1 */
複製程式碼
專案佔據的空間,預設值為auto,即專案的本來大小
flex-basis: <length> | auto; /* default auto */
複製程式碼
簡寫:flex-grow, flex-shrink 和 flex-basis
flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
複製程式碼
獨立的對齊方式
align-self: auto | flex-start | flex-end | center | baseline | stretch;
複製程式碼
關於專案屬性flex的理解:
簡寫形式 | 完整形式 |
---|---|
預設值 | flex : 0 1 auto; |
flex : 1 | flex : 1 1 0%; |
flex: auto | flex : 1 1 auto; |
flex : none | flex: 0 0 auto; |
flex : 0% | flex : 1 1 0%; |
flex : 2 3 | flex : 2 3 0%; |
flex : 2 3px | flex : 2 1 3px; |
注意:重點理解flex:1跟flex:auto的區別,本質上是flex-basis的理解。
flexbox在分配剩餘空間時,需要計算剩餘空間的大小,這依賴於flex-basis。
flex:1時flex-basis是0%,也就是元素就算設定了width也不會起作用,基準寬度為0,元素的最終寬度是分配了剩餘寬度後得到的尺寸。
flex:auto時,flex-basis是auto,基準寬度為元素設定的width,最終寬度等於基準寬度+剩餘寬度分配後的寬度。