彈性布局(display:flex;)屬性詳解
Flexbox 是 flexible box 的簡(jiǎn)稱(chēng)(注:意思是“靈活的盒子容器”)巢寡,是 CSS3 引入的新的布局模式序调。它決定了元素如何在頁(yè)面上排列,使它們能在不同的屏幕尺寸和設(shè)備下可預(yù)測(cè)地展現(xiàn)出來(lái)停局。
它之所以被稱(chēng)為 Flexbox ,是因?yàn)樗軌驍U(kuò)展和收縮 flex 容器內(nèi)的元素闽烙,以最大限度地填充可用空間每界。與以前布局方式(如 table 布局和浮動(dòng)元素內(nèi)嵌塊元素)相比,F(xiàn)lexbox 是一個(gè)更強(qiáng)大的方式:
- 在不同方向排列元素
- 重新排列元素的顯示順序
- 更改元素的對(duì)齊方式
- 動(dòng)態(tài)地將元素裝入容器
一钱反、基本概念
采用 Flex 布局的元素掖看,稱(chēng)為 Flex 容器(flex container)匣距,簡(jiǎn)稱(chēng)"容器"。它的所有子元素自動(dòng)成為容器成員哎壳,稱(chēng)為 Flex 項(xiàng)目(flex item)毅待,簡(jiǎn)稱(chēng)"項(xiàng)目"。
在 Flexbox 模型中耳峦,有三個(gè)核心概念:
– flex 項(xiàng)(注:也稱(chēng) flex 子元素)恩静,需要布局的元素
– flex 容器,其包含 flex 項(xiàng)
– 排列方向(direction)蹲坷,這決定了 flex 項(xiàng)的布局方向
二驶乾、容器屬性
2.1 flex-direction:
- row(默認(rèn)值):主軸為水平方向,起點(diǎn)在左端循签。
- row-reverse:主軸為水平方向级乐,起點(diǎn)在右端。
- column:主軸為垂直方向县匠,起點(diǎn)在上沿风科。
- column-reverse:主軸為垂直方向,起點(diǎn)在下沿乞旦。
2.2 flex-wrap:
- nowrap(默認(rèn)):不換行贼穆。
- wrap:換行,第一行在上方兰粉。
- wrap-reverse:換行故痊,第一行在下方。
2.3 justify-content:
- flex-start(默認(rèn)值):左對(duì)齊
- flex-end:右對(duì)齊
- center: 居中
- space-between:兩端對(duì)齊玖姑,項(xiàng)目之間的間隔都相等愕秫。
- space-around:每個(gè)項(xiàng)目?jī)蓚?cè)的間隔相等。所以焰络,項(xiàng)目之間的間隔比項(xiàng)目與邊框的間隔大一倍戴甩。
2.4 align-items:
- flex-start:交叉軸的起點(diǎn)對(duì)齊。
- flex-end:交叉軸的終點(diǎn)對(duì)齊闪彼。
- center:交叉軸的中點(diǎn)對(duì)齊甜孤。
- baseline: 項(xiàng)目的第一行文字的基線(xiàn)對(duì)齊。
- stretch(默認(rèn)值):如果項(xiàng)目未設(shè)置高度或設(shè)為auto畏腕,將占滿(mǎn)整個(gè)容器的高度课蔬。
2.5 align-content:
定義了多根軸線(xiàn)的對(duì)齊方式,如果項(xiàng)目只有一根軸線(xiàn)郊尝,那么該屬性將不起作用
- flex-start:與交叉軸的起點(diǎn)對(duì)齊二跋。
- flex-end:與交叉軸的終點(diǎn)對(duì)齊。
- center:與交叉軸的中點(diǎn)對(duì)齊流昏。
- space-between:與交叉軸兩端對(duì)齊扎即,軸線(xiàn)之間的間隔平均分布吞获。
- space-around:每根軸線(xiàn)兩側(cè)的間隔都相等。所以谚鄙,軸線(xiàn)之間的間隔比軸線(xiàn)與邊框的間隔大一倍各拷。
- stretch(默認(rèn)值):軸線(xiàn)占滿(mǎn)整個(gè)交叉軸。
結(jié)合 justify-content
和align-items
闷营,看看在 flex-direction
兩個(gè)不同屬性值的作用下烤黍,軸心有什么不同:
三、項(xiàng)目屬性
3.1 order屬性
3.2 flex-grow屬性
flex-grow
屬性定義項(xiàng)目的放大比例傻盟,默認(rèn)為0
速蕊,即如果存在剩余空間,也不放大娘赴。
如果所有項(xiàng)目的flex-grow
屬性都為1规哲,則它們將等分剩余空間(如果有的話(huà))。如果一個(gè)項(xiàng)目的flex-grow
屬性為2诽表,其他項(xiàng)目都為1唉锌,則前者占據(jù)的剩余空間將比其他項(xiàng)多一倍。
3.3 flex-shrink屬性
flex-shrink
屬性定義了項(xiàng)目的縮小比例竿奏,默認(rèn)為1袄简,即如果空間不足,該項(xiàng)目將縮小泛啸。
.item {
flex-shrink: <number>; /* default 1 */
}
如果所有項(xiàng)目的flex-shrink
屬性都為1痘番,當(dāng)空間不足時(shí),都將等比例縮小平痰。如果一個(gè)項(xiàng)目的flex-shrink
屬性為0,其他項(xiàng)目都為1伍纫,則空間不足時(shí)宗雇,前者不縮小。
負(fù)值對(duì)該屬性無(wú)效莹规。
3.4 align-self屬性
align-self
屬性允許單個(gè)項(xiàng)目有與其他項(xiàng)目不一樣的對(duì)齊方式赔蒲,可覆蓋align-items
屬性。默認(rèn)值為auto
良漱,表示繼承父元素的align-items
屬性舞虱,如果沒(méi)有父元素,則等同于stretch
母市。
.item {
align-self: auto | flex-start | flex-end | center | baseline | stretch;
}
彈性布局默認(rèn)不改變項(xiàng)目的寬度矾兜,但是它默認(rèn)改變項(xiàng)目的高度。如果項(xiàng)目沒(méi)有顯式指定高度患久,就將占據(jù)容器的所有高度椅寺。