详解CSS的Flex布局

52次阅读

共计 2036 个字符,预计需要花费 6 分钟才能阅读完成。

本文由云 + 社区发表
Flex 是 Flexible Box 的缩写,意为 ” 弹性布局 ”,是 CSS3 的一种布局模式。通过 Flex 布局,可以很优雅地解决很多 CSS 布局的问题。下面会分别介绍容器的 6 个属性和项目的 6 个属性。每个属性会附上效果图,具体实现代码会以 github 路径形式更新于此。
1. 浏览器支持情况
可以点击查看各浏览器的兼容情况
2. 容器的属性
注意,设为 Flex 布局以后,子元素的 float、clear 和 vertical-align 属性将失效。
容器的属性有 6 个,分别是:
flex-direction
flex-wrap
flex-flow
justify-content
align-items
align-content
(1)flex-direcion 属性:
作用:控制主轴的方向
flex-direction: row | row-reverse | column | column-reverse;
默认值:row

(2)flex-wrap 属性:
作用:默认情况下,项目都排在一条线(又称 ” 轴线 ”)上。flex-wrap 属性定义,如果一条轴线排不下,如何换行。
flex-wrap: nowrap | wrap | wrap-reverse;
默认值:nowrap

(3)flex-flow 属性
作用:该属性是 flex-direction 属性和 flex-wrap 属性的简写形式
默认值:row nowrap
(4)justify-content 属性
作用:定义项目在主轴上的对齐方式
justify-content: flex-start | flex-end | center | space-between | space-around;
默认值:flex-start

(5)align-items 属性
作用:定义项目在交叉轴上如何对齐。
align-items: flex-start | flex-end | center | baseline | stretch
默认值:flex-start

注意:如果 align-items 为 stretch,想看到每个 flex-item 铺满整个交叉轴的话,需要设置所有的 flex-item 的高度:height:auto,否则达不到效果。
(6)align-content 属性
属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
默认值:stretch
flex-start:与交叉轴的起点对齐。
flex-end:与交叉轴的终点对齐。
center:与交叉轴的中点对齐。
space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
stretch:轴线占满整个交叉轴。

3. 项目的属性
项目的属性有 6 个,分别是:
order
flex-grow
flex-shrink
flex-basis
flex
align-self
(1)order 属性:
作用:定义项目的排列顺序,数值越小,排列越靠前。
默认值:0

(2)flex-grow 属性
作用:如果存在剩余空间,项目放大的比例。相当于是各个项目根据这个比例,来分配剩余空间。
默认值:0(不放大)

(3)flex-shrink 属性
作用:flex-shrink:如果存在空间不足,项目的“缩小比例”。0 表示当空间不足时,不缩小。
默认值:1
负值对该属性无效

(4)flex-basis 属性
作用:定义项目在主轴方向上占据空间大小的初值。
默认值:auto(项目本来的大小)
(5)flex 属性
作用:是 flex-grow、flex-shrink、flex-basis 属性的缩写形式;
flex: none | [<‘flex-grow’> <‘flex-shrink’>? || <‘flex-basis’>]
注:几种常见缩写形式;
flex: auto; === flex: 1 1 auto;
flex: none; === flex: 0 0 auto;
flex: initial; === flex: 0 1 auto;
flex: <number>; === flex: <number>1 auto;
flex: 1; === flex: 1 1 auto;
建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值
(6)align-self 属性
作用:属性允许单个项目有与其他项目不一样的对齐方式,可覆盖 align-items 属性。
align-self: auto | flex-start | flex-end | center | baseline | stretch;
默认值:auto,表示继承父元素的 align-items 属性,如果没有父元素,则等同于 stretch。

4. 小结
本文分别介绍了容器的 6 个属性和 flex-item 项目的 6 个属性。建议跟着 demo 整体做一遍,有助于加深理解。如有问题,欢迎指正。
此文已由作者授权腾讯云 + 社区发布

正文完
 0