Flex布局,也称为弹性布局,是CSS3新引入的一种布局方式。
相比于传统的布局方式,Flex布局提供了更加强大而灵活的布局方式。
本文将详细介绍Flex布局的主要属性。
容器属性
在Flex布局中,容器(父元素)和项目(子元素)有各自的属性。首先,我们看一下容器的主要属性:
- display:设为
flex
或inline-flex
可以将一个元素设为Flex容器。 - flex-direction:定义了项目的主轴方向,取值可以是
row
(默认值,水平方向)、row-reverse
(水平反向)、column
(垂直方向)和column-reverse
(垂直反向)。 - flex-wrap:定义了当一行的项目无法容纳更多项目时是否换行,取值可以是
nowrap
(默认值,不换行)、wrap
(换行,第一行在上方)和wrap-reverse
(换行,第一行在下方)。 - flex-flow:是
flex-direction
和flex-wrap
两个属性的简写形式。 - justify-content:定义了项目在主轴上的对齐方式,取值可以是
flex-start
(默认值,左对齐)、flex-end
(右对齐)、center
(居中对齐)、space-between
(两端对齐)和space-around
(平均分配空间)。 - align-items:定义了项目在交叉轴上的对齐方式,取值可以是
stretch
(默认值,如果项目未设置高度或设为auto,将占满整个容器的高度)、flex-start
(交叉轴的起点对齐)、flex-end
(交叉轴的终点对齐)、center
(交叉轴的中点对齐)和baseline
(项目的第一行文字的基线对齐)。 - align-content:定义了多行的项目在交叉轴上的对齐方式,取值与
align-items
相同。
项目属性
接下来,我们看一下项目的主要属性:
- order:定义了项目的排列顺序,数值越小,排列越前,默认为0。
- flex-grow:定义了项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
- flex-shrink:定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
- flex-basis:定义了在分配多余空间之前,项目占据的主轴空间。浏览器根据这个属性,计算主轴是否有多余空间。
- flex:是
flex-grow
、flex-shrink
和flex-basis
的简写,默认值为0 1 auto
。后两个属性可选。 - align-self:允许单个项目有与其他项目不一样的对齐方式,可覆盖
align-items
属性。默认值为auto
,表示继承父元素的align-items
属性,如果没有父元素,则等同于stretch
。
通过以上属性,Flex布局可以实现大多数布局需求,并且代码简洁、易于理解。