弹性盒子布局(flex布局)

弹性盒子布局方式:
.box{
display:flex;
}
@设为Flex布局后,子元素的float、clear和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。
/**容器属性设置**/
1.flex-direction属性
决定主轴的方向(即项目的排列方向)
//水平方向
row(默认值) 主轴方向为水平方向,起点在左端
row-reverse 主轴方向为水平方向,起点在右端
//垂直方向
column 主轴方向为垂直方向,起点在上沿
column-reverse 主轴方向为垂直方向,起点在下沿
2.flex-wrap属性
默认情况下,项目都排在一条线(又称“轴线”)上。
flex-wrap属性定义了,如果一条轴线排不下,如何换行
nowrap(默认) 不换行
wrap 换行,第一行在上方
wrap-reverse 换行,第一行在下方
3.flex-flo属性:
是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap
4.justify-content属性
justify-content属性定义了项目在主轴上的对其方式
flex-start(默认值) 左对齐
flex-end 右对齐
center 居中
space-between 两端对齐,项目之间的间隔都相等
space-around 每个项目两侧的间隔相等,所以,项目之间的间隔比项目与边框的间隔大一倍
5.align-items属性
定义项目在交叉轴上如何对其
flex-start 交叉轴的起点对齐
flex-end 交叉轴的终点对齐
center 交叉轴的中点对齐
baseline 项目的第一行文字的基线对齐
stretch(默认值) 如果项目未设置高或设为auto,将占满整个容器的高度
6.align-content属性
定义了多根轴线的对齐方式,如果项目只有一根轴线,该属性不起作用
flex-start 与交叉轴的起点对齐
flex-end 与交叉轴的终点对齐
center 与交叉轴的中点对齐
space-between 与交叉轴两端对齐,轴线之间的间隔平均分布
space-around 每根轴线两侧的间隔都相等,所以轴线之间的间隔比轴线与边框的间隔大一倍
stretch(默认值) 轴线占满整个交叉轴

/**项目属性**/
order:定义项目排列的顺序。数值越小,排列越靠前,默认为0
flex-grow:定义项目的放大比例,默认为0,如果存在空白部分,也不会放大
flex-shrink:定义了项目的缩小比例,默认为1,如果空间不足,该项目将缩小
flex-basis:定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目本来的大小
flex:是flex-grow,flex-shrink和flex-basis的简写,默认值为0 1 auto,后两个属性可选
align-self:允许单个的项目有与其他项目不一样的对齐方式,可覆盖align-item属性。默认为auto,表示继承父元素的align-item属性,如果没有父元素,则等同于stretch

猜你喜欢

转载自www.cnblogs.com/tsim/p/11326261.html