Flex布局 常用属性说明
Flex 是 Flexible Box 的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。
任何一个容器都可以指定为 Flex 布局
.box{
display: flex;
}
行内元素也可以使用 Flex 布局。
.box{
display: inline-flex;
}
设为 Flex 布局以后,它的所有子元素自动成为容器成员,子元素的float、clear和vertical-align属性将失效
容器默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)。
1.容器的属性有六个
flex-direction / 主轴的方向
flex-wrap / 排不下时如何换行
flex-flow / 上面两个属性的简写
justify-content / 项目在主轴(x轴)上的对齐方式
align-items / 在交叉轴(y轴)上的对齐方式
align-content / 多根轴线的对齐方式
flex-direction
属性决定主轴的方向(即项目的排列方向)。
row(默认值):主轴为水平方向,起点在左端。
row-reverse:主轴为水平方向,起点在右端。
column:主轴为垂直方向,起点在上沿。
column-reverse:主轴为垂直方向,起点在下沿。
flex-wrap
属性定义如果一条轴线排不下,如何换行。
nowrap(默认):不换行。
wrap:换行,第一行在上方。
wrap-reverse:换行,第一行在下方。
flex-flow
属性是上面两个属性的简写形式,默认值为row nowrap。
justify-content
属性定义项目在主轴(x轴)上的对齐方式默认左对齐
center: 中间对齐
flex-end: 右对齐
space-between: 主轴两边对齐项目之间间隔相等
space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。
align-items
在交叉轴(y轴)上的对齐方式默认上对齐
center:中间对齐
flex-start:顶对齐
flex-end: 底部对齐
align-content
属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
2.项目的属性有六个
order / 项目的排列顺序
flex-grow / 项目的放大比例
flex-shrink / 项目的缩小比例
flex-basis / 项目占据的主轴空间
flex / 上面三个的简写
align-self / 项目的对齐方式
order
属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。
flex-grow
属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。
flex-shrink
属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
flex-basis
属性定义了在分配多余空间之前,项目占据的主轴空间
它可以设为跟width或height属性一样的值(比如350px),则项目将占据固定空间。
flex
属性是上面三个属性的简写,默认值为0 1 auto。后两个属性可选。
建议优先使用这个属性,而不是单独写三个分离的属性
align-self
属性允许单个项目有与其他项目不一样的对齐方式,可覆盖容器的align-items属性
center