基本概念
- flex 默認(rèn)存在兩根軸:水平的主軸(main axis)和垂直的交叉軸(cross axis)昌妹。主軸的開始位置(與邊框的交叉點(diǎn))叫做main start,結(jié)束位置叫做main end拉岁;交叉軸的開始位置叫做cross start情组,結(jié)束位置叫做cross end丈挟。
項(xiàng)目默認(rèn)沿主軸排列获枝。單個(gè)項(xiàng)目占據(jù)的主軸空間叫做main size,占據(jù)的交叉軸空間叫做cross size闯割。
容器的屬性
- flex-direction 屬性決定主軸的方向(即項(xiàng)目的排列方向)彻消。
- row(默認(rèn)值):主軸為水平方向,起點(diǎn)在左端宙拉。
- row-reverse:主軸為水平方向宾尚,起點(diǎn)在右端。
- column:主軸為垂直方向谢澈,起點(diǎn)在上沿煌贴。
- column-reverse:主軸為垂直方向,起點(diǎn)在下沿澳化。
- flex-wrap屬性定義,如果一條軸線排不下稳吮,如何換行
- nowrap(默認(rèn)):不換行
- wrap:換行缎谷,第一行在上方
- wrap-reverse:換行,第一行在下方
- flex-flow 屬性是flex-direction屬性和flex-wrap屬性的簡(jiǎn)寫形式灶似,默認(rèn)值為row nowrap列林。
- justify-content 屬性定義了項(xiàng)目在主軸上的對(duì)齊方式。
- flex-strart(默認(rèn)值):左對(duì)齊
- flex-end:右對(duì)齊
- center:居中
- space-between:兩端對(duì)齊酪惭,項(xiàng)目之間的間隔都相等
- space-around:每個(gè)項(xiàng)目?jī)蓚?cè)的間隔相等希痴。所以,項(xiàng)目之間的間隔比項(xiàng)目與邊框的間隔大一倍
- align-items:屬性定義項(xiàng)目在交叉軸上如何對(duì)齊
- flex-start:交叉軸的起點(diǎn)對(duì)齊
- flex-end:交叉軸的終點(diǎn)對(duì)齊
- center:交叉軸的中點(diǎn)對(duì)齊(所謂的居中對(duì)齊)
- baseline:項(xiàng)目的第一行文字的基線對(duì)齊
- stretch(默認(rèn)值):如果項(xiàng)目未設(shè)置高度或設(shè)為auto春感,將占滿整個(gè)容器的高度砌创。
- align-content屬性定義了多根軸線的對(duì)齊方式虏缸。如果項(xiàng)目只有一根軸線,該屬性不起作用
- flex-start:與交叉軸的起點(diǎn)對(duì)齊
- flex-end:與交叉軸的終點(diǎn)對(duì)齊
- center:與交叉軸的中點(diǎn)對(duì)齊
- space-between:與交叉軸兩端對(duì)齊嫩实,軸線之間的間隔平均分布
- space-around:沒根軸線兩側(cè)的間隔都相等刽辙。所以,軸線之間的間隔比軸線與邊框的間隔大一倍
- stretch(默認(rèn)值):軸線占滿整個(gè)交叉軸
子元素屬性
- order 屬性定義項(xiàng)目的排列順序甲献。數(shù)值越小宰缤,排列越靠前,默認(rèn)為0晃洒。
- flex-grow 屬性定義項(xiàng)目的放大比例慨灭,默認(rèn)為0,即如果存在剩余空間球及,也不放大氧骤。
- 如果所有項(xiàng)目的flex-grow屬性都為1,則它們將等分剩余空間(如果有的話)桶略。如果一個(gè)項(xiàng)目的flex-grow屬性為2语淘,其他項(xiàng)目都為1,則前者占據(jù)的剩余空間將比其他項(xiàng)多一倍际歼。
- flex-shrink 屬性定義了項(xiàng)目的縮小比例惶翻,默認(rèn)為1,即如果空間不足鹅心,該項(xiàng)目將縮小吕粗。(一般都不會(huì)用到這個(gè)屬性),負(fù)值對(duì)該屬性無效
- flex-basis 屬性定義了在分配多余空間之前旭愧,項(xiàng)目占據(jù)的主軸空間(main size)颅筋。瀏覽器根據(jù)這個(gè)屬性,計(jì)算主軸是否有多余空間输枯。它的默認(rèn)值為auto议泵,即項(xiàng)目的本來大小。
- flex 屬性是flex-grow, flex-shrink 和 flex-basis的簡(jiǎn)寫桃熄,默認(rèn)值為0 1 auto先口。后兩個(gè)屬性可選。(建議優(yōu)先使用這個(gè)屬性瞳收,而不是單獨(dú)寫三個(gè)分離的屬性碉京,因?yàn)闉g覽器會(huì)推算相關(guān)值)
- align-self 屬性允許單個(gè)項(xiàng)目有與其他項(xiàng)目不一樣的對(duì)齊方式,可覆蓋align-items屬性螟深。默認(rèn)值為auto谐宙,表示繼承父元素的align-items屬性,如果沒有父元素界弧,則等同于stretch凡蜻。(該屬性可能取6個(gè)值搭综,除了auto,其他都與align-items屬性完全一致咽瓷。)
具體實(shí)戰(zhàn)還是看阮一峰老師實(shí)戰(zhàn)