一般的布局是基於盒模型,使用display屬性 + float屬性 + position屬性。flex是h5中新增的頁面布局方案。
一:flex布局是什么。
flex是Flexible Box,就是“彈性布局”。它具有非常好的靈活性。
任何容器都可以開啟彈性布局。
.box{ display:flex};
行內元素開啟彈性布局
.box{ dispaly: inline-flex};
webkit內核的瀏覽器,需要加前綴-webkit-
.box{ display: -webkit-flex;
display: flex;
}
注意:當開啟flex后,子元素的float,cleat,vertical-align將失效
二:基本概念。
采用Flex布局的元素,稱為Flex容器(flex container),簡稱"容器"。它的所有子元素自動成為容器成員,稱為Flex項目(flex item),簡稱"項目"。
容器默認存在兩根軸:水平的主軸(main axis)和垂直的交叉軸(cross axis)。主軸的開始位置(與邊框的交叉點)叫做main start
,結束位置叫做main end
;
交叉軸的開始位置叫做cross start
,結束位置叫做cross end
。項目默認沿主軸排列。單個項目占據的主軸空間叫做main size
,占據的交叉軸空間叫做cross size
。
三:容器的屬性
下面6個屬性設置在容器上
- flex-direction
- flex-wrap
- flex-flow
- justify-content
- align-items
- align-content
3.1 flex-direction屬性
它決定了主軸的方向
.box{
flex-direction: row | row-reverse | column | column-reverse;
}
它有4個屬性值分別是:
row
(默認值):主軸為水平方向,起點在左端。row-reverse
:主軸為水平方向,起點在右端。column
:主軸為垂直方向,起點在上沿。column-reverse
:主軸為垂直方向,起點在下沿。
3.2 flex-wrap屬性
默認情況下,項目都排在一條線(又稱"軸線")上。flex-wrap
屬性定義,如果一條軸線排不下,如何換行。
.box{
flex-wrap: nowrap | wrap | wrap-reverse;
}
它有3個屬性值
- nowrap(默認值),不換行
- wrap 換行,第一行在上面
- wrap-reverse 換行,第一行在下面
3.3 flex-flow屬性
flex-flow是 flex-direction屬性 和 flex-wrap屬性的簡寫形式,默認值為row nowrap
.box{
flex-flow: <flex-direction> || <flex-wrap>;
}
3.4 justify-content屬性
justify-content是設置子元素在主軸上對其的方式
.box{
justify-content: flex-start | flex-end | center | space-between | space-around;
}
它有5個值
flex-start
(默認值):左對齊flex-end
:右對齊center
: 居中space-between
:兩端對齊,項目之間的間隔都相等。space-around
:每個項目兩側的間隔相等。所以,項目之間的間隔比項目與邊框的間隔大一倍。
3.5 align-item屬性
align-item定義子元素在交叉軸上是怎么對其
.box{
align-item: flex-start | flex-end | flex-center | baseline | stretch;
}
它有5個屬性值
flex-start
:交叉軸的起點對齊。flex-end
:交叉軸的終點對齊。center
:交叉軸的中點對齊。baseline
: 項目的第一行文字的基線對齊。stretch
(默認值):如果項目未設置高度或設為auto,將占滿整個容器的高度。
3.6 align-content屬性
定義多根軸線的對其方式,如果就項目只有一個軸線,該屬性不起作用
.box{
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
它有6個屬性值
flex-start
:與交叉軸的起點對齊。flex-end
:與交叉軸的終點對齊。center
:與交叉軸的中點對齊。space-between
:與交叉軸兩端對齊,軸線之間的間隔平均分布。space-around
:每根軸線兩側的間隔都相等。所以,軸線之間的間隔比軸線與邊框的間隔大一倍。stretch
(默認值):軸線占滿整個交叉軸。
四. 項目屬性
下面這6個屬性設置在項目上
order
flex-grow
flex-shrink
flex-basis
flex
align-self
4.1 order屬性
它是定義項目的排列順序。數值越小,排列越靠前,默認為0.
.item{
order: <integer>(整數);
}
4.2 flex-grow屬性
flex-grow定義項目放大的比例,默認為0,即還存在剩余空間,也不會在放大。
.item{
flex-grow: <number>;
}
如果所有項目的flex-grow的值為1時,則它們將等分剩余空間。如果有一個項目flex-grow的值是2,其它為1時,那么前者占據的剩余空間時其它的2倍。
4.3 flex-shrink屬性
flex-shrink定義項目的縮小比例,默認值為1.即空間不足,該項目將縮小。
.item{
flex-shrink: <number>;
}
如果所有項目的flex-shrink的值為1時,當空間不足時,都將等比例縮放。如果有一個項目flex-grow的值是0,其它為1時,那么前者將不縮小。
負值無效。
4.4 flex-basis屬性
flex-basis定義在了在分配多余的空間之前,項目占據的主軸空間。
瀏覽器是根據這個屬性來計算主軸是否有多余空間。他默認是auto,即項目本來的大小。
.item{
flex-basis: <length> | auto;
}
它可以設為跟width
或height
屬性一樣的值(比如350px),則項目將占據固定空間。
4.5 flex屬性
flex
屬性是flex-grow
, flex-shrink
和 flex-basis
的簡寫,默認值為0 1 auto
。后兩個屬性可選。
.item{
flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ];
}
該屬性有2個快捷值auto(1,1,auto)和 none(0,0,auto)
建議使用該屬性,瀏覽器會自動推算其他值
4.6 align-self屬性
align-self
屬性允許單個項目有與其他項目不一樣的對齊方式,可覆蓋align-items
屬性。默認值為auto
,表示繼承父元素的align-items
屬性,如果沒有父元素,則等同於stretch
。
.item { align-self: auto | flex-start | flex-end | center | baseline | stretch; }
該屬性可能取6個值,除了auto,其他都與align-items屬性完全一致。
此文參考阮一峰的網絡日志:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html