Flex布局
flex布局是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
任何一个容器都可以指定为 Flex 布局,包括行内元素,例如:
.box{
display: inline-flex;
}
Webkit 内核的浏览器,必须加上-webkit前缀。
.box{
display: -webkit-flex; /* Safari */
display: flex;
}
注意,设为 Flex 布局以后,子元素的float、clear和vertical-align属性将失效。
Flex 容器(flex container),它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称"项目"。
1、flex容器有六个基本属性:
? flex-direction
? flex-wrap
? flex-flow
? justify-content
? align-items
? align-content
1.1、flex-direction属性决定主轴的方向(即项目的排列方向)
flex-direction: row | row-reverse | column | column-reverse;
? row:默认值,横向排列,主轴为水平方向,起点在左端
? column:纵向排列,主轴为垂直方向,起点在上沿
1.2、flex-wrap属性(如何换行)
flex-wrap: nowrap | wrap | wrap-reverse;
? nowrap(默认值):不换行
? wrap:换行,第一行在上方
? wrap-reverse:换行,第一行在下方
1.3、flex-flow
flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
1.4、justify-content属性
justify-content属性定义了项目在主轴上的对齐方式。
justify-content: flex-start | flex-end | center | space-between | space-around;
? space-between:两端对齐,项目之间的间隔都相等
? space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍
1.5、align-items属性
align-items属性定义项目在交叉轴上如何对齐
align-items: flex-start | flex-end | center | baseline | stretch;
? baseline: 项目的第一行文字的基线对齐
? stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度
1.6、align-content属性
align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
? flex-start:与交叉轴的起点对齐
? flex-end:与交叉轴的终点对齐
? center:与交叉轴的中点对齐
? space-between:与交叉轴两端对齐,轴线之间的间隔平均分布
? space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍
? stretch(默认值):轴线占满整个交叉轴
2、flex项目六个属性
? order
? flex-grow
? flex-shrink
? flex-basis
? flex
? align-self
2.1、order属性
order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0
order: <integer>
2.2、flex-grow属性
flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
flex-grow: <number>;
如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。
2.3、flex-shrink属性
flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
flex-shrink: <number>; /* default 1 */
如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。
负值对该属性无效
2.4、flex-basis属性
flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。
flex-basis: <length> | auto; /* default auto */
它可以设为跟width或height属性一样的值(比如350px),则项目将占据固定空间。
? auto:首先检索该项目(子元素)的主尺寸,如果主尺寸不为 auto,则使用值采取主尺寸之值;如果也是 auto,则使用值为 content。
? content:指根据该项目(子元素)的内容自动布局。有的用户代理没有实现取 content 值,等效的替代方案是 flex-basis 和主尺寸都取 auto。
? 百分比:根据其flex容器(即伸缩父容器)的主尺寸计算。如果flex容器的主尺寸未定义(即父容器的主尺寸取决于子元素),则计算结果和设为 auto 一样。
2.5、flex属性
flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值
当 flex 取值为 none,则计算值为 0 0 auto;
当 flex 取值为 auto,则计算值为 1 1 auto;
当 flex 取值为一个非负数字,则该数字为 flex-grow 值,flex-shrink 取 1,flex-basis 取 0%;
当 flex 取值为一个长度或百分比,则视为 flex-basis 值,flex-grow 取 1,flex-shrink 取 1;
当 flex 取值为两个非负数字,则分别视为 flex-grow 和 flex-shrink 的值,flex-basis 取 0%;
当 flex 取值为一个非负数字和一个长度或百分比,则分别视为 flex-grow 和 flex-basis 的值,flex-shrink 取 1
2.6、align-self属性
align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
align-self: auto | flex-start | flex-end | center | baseline | stretch;