弹性盒子布局

弹性盒子(Flexible Box)是一种用于按行或按列布局元素的一维布局方法,使用该布局的组件即为弹性容器(flex container),容器内的直系子组件则是弹性项目(flex item),他们可以膨胀以填充额外的空间,收缩以适应更小的空间,它们在 CSS 属性都为初始的情况下都会有下列行为:

  • 项目排列成一行。(容器的 flex-direction 属性的初始值是 row

  • 项目从主轴的起始线开始。(容器的 justify-content 属性的初始值是 flex-start

  • 项目不会在主轴维度方向拉伸,但可以缩小。(项目的 flex-growflex-shirnk 属性的初始值分别是 01

  • 元素被拉升来填充交叉轴大小。(容器的 align-items 属性初始值是 stretch

该布局中存在主轴(main axis)和交叉轴(cross axis),主轴由 flex-direction 定义,交叉轴垂直于主轴,容器内的项目沿着主轴排列,当主轴排满项目后,如果 flex-wrap 值为 wrap 则会沿着交叉轴追加新的主轴并在新主轴上继续排列。

如需了解更多关于弹性盒子布局的概念和用法,可参考 MDN 上的文档:《flex 布局的基本概念 - CSS(层叠样式表) | MDN

test/test_flex_layout.c 展示了常见布局的实现方法,效果与下面的在线示例一致,你也可以编译并运行它来体验实际效果。

最后更新于