目录
介绍
容器默认存在两根轴:水平的主轴和垂直的交叉轴
使用弹性盒布局的父元素 display:flex;
给父元素设置display:flex,达到控制子元素的目的
常见的父项属性
flex-direction 设置主轴方向 | row(默认值):主轴为水平方向,起点在左端 |
row-reverse:主轴为水平方向,起点在右端 | |
column:主轴为垂直方向,起点在上沿 | |
column-relative:主轴为垂直方向,起点在下沿 | |
justify-content 设置主轴上的子元素排列方式 | flex-start:左对齐 |
flex-end:右对齐 | |
center:居中 | |
space-between:两端对齐,项目之间的间隔相等 | |
space-around:每个项目两端间隔相等 | |
flex-wrap 设置子元素是否换行 | nowrap:(默认):不换行 |
wrap:换行,第一行在上方 | |
wrap-relative:换行,第一行在下方 | |
aline-content 设置侧轴上的子元素的排列方式(多行) | flex-start:与交叉轴的起点对齐 |
flex-end:与交叉轴的终点对齐 | |
content:与交叉轴的中点对齐 | |
space-between:与交叉轴两端对齐,轴线之间平均分布 | |
space-around:每根轴线两侧的间隔都相等,所以,轴线之间的间隔比轴线与边框的间隔大一倍 | |
stretch(默认值) | |
align-items 设置侧轴上的子元素排列方式(单行) | flex-start:交叉轴起点对齐 |
flex-end:交叉轴的终点对齐 | |
center:交叉轴的中点对齐 | |
baseline:项目的第一行文字的基线对齐 | |
stretch(默认值):如果项目没设置高度或设auto,将占满整个容器 | |
flex-flow:复合属性 相当于同时设置了flex-direction和flex-wrap |
项目属性
order:该属性定义了项目的排列顺序,数值越小,排列越靠前,默认0
flex-grow:该属性定义了项目的放大比例,默认0,即如果存在剩余空间,也不放大
flex-shrink:该属性定义了项目的缩小比例,默认为1,即如果剩余空间不足,该项目将缩小
flex-basis:该属性定义了在分配多余空间之前,项目占据的主轴空间
flex-grow、flex-shrink、flex-basis的速写形式是flex