一文搞懂flex(弹性盒布局)

彩虹网

1、什么是弹性布局

Flex是Flexible Box的缩写,翻译成中文就是“弹性盒子”,用来为盒装模型提供最大的灵活性。任何一个容器都可以指定为Flex布局。

她是一种现代的CSS布局方式,通过使用display: flex属性来创建一个弹性容器,可以自动适配各种设备的不同宽度,而不必依赖于传统的块状布局和浮动定位,并在其中使用灵活的盒子模型来进行元素的排列和定位。

在浏览器支持完美的环境中,选择使用弹性盒子的原因是你希望把一系列项目沿着同一方向布局。因为在放置元素过程中,你想控制元素在那个方向的维度,或者控制它们彼此之间的间距。弹性盒子就是为此设计的。

2、弹性布局的特点

一文搞懂flex(弹性盒布局)

3、Flex容器

我们把一个容器的 display 属性值改为 flex 或者 inline-flex 之后,该容器就变成了 Flex 容器,而容器中的直系子元素就会变为 flex 元素。如下代码所示,parent 元素就是 Flex 容器,son 元素就是 Flex 元素。

一文搞懂flex(弹性盒布局)


由于所有 CSS 属性都会有一个初始值,所以 flex 容器中的所有 flex 元素都会有下列行为:

4、Flex容器属性

一文搞懂flex(弹性盒布局)

4.1、flex-direction:决定主轴的方向(即项目的排列方向)

.box {
   flex-direction: row | row-reverse | column | column-reverse;
}

如果你选择了 row 或者 row-reverse,那么主轴(Main Axis)就是横向的 X 轴,交叉轴(Cross Axis)就是竖向的 Y 轴,如下图所示。

一文搞懂flex(弹性盒布局)

如果你选择了 column 或者 column-reverse,那么主轴(Main Axis)就变成是竖向的 Y 轴,交叉轴(Cross Axis)就是横向的 X 轴,如下图所示。

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

4.2、flex-wrap:定义换行情况

一文搞懂flex(弹性盒布局)

默认元素排列在一条轴线上,如果一条轴线排不下,此时就可以用flex-wrap属性处理。

.box{
   flex-wrap: nowrap | wrap | wrap-reverse;
}

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

4.3、justify-content:定义项目在主轴上的对齐方式

justify-content 属性用来使元素在主轴方向上对齐,它的初始值是 flex-start,即元素从容器的起始线排列。justify-content 属性有如下 5 个不同的值:

一文搞懂flex(弹性盒布局)

对齐方式与轴的方向有关,本文中假设主轴从左到右。

.box {
   justify-content: start | end | flex-start | flex-end | center | left | right | space-between | space-around | space-evenly | stretch | safe | unsafe | baseline | first baseline | last baseline;
}

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

4.4、align-items:定义在交叉轴上的对齐方式

align-items 属性可以使元素在交叉轴方向对齐,它的初始值是 stretch,即拉伸到最高元素的高度。align-items 属性有如下 5 个不同的值:

一文搞懂flex(弹性盒布局)

对齐方式与交叉轴的方向有关,假设交叉轴从下到上。

.box{
    align-items: flex-start | flex-end | center | baseline | stretch;
}

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

4.5、align-content:定义多根轴线的对齐方式

定义了多根轴线的对齐方式,如果项目只有一根轴线,那么该属性将不起作用

如果项目只有一根轴线,该属性不起作用。 所以,容器必须设置flex-wrap:···;

.box{
    align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

当你不给项目设置高度但是给容器设置align-content不为stretch时,同一轴线上的项目的高度将等于项目中高度最高的项目。

一文搞懂flex(弹性盒布局)

4.6、align-content 和 align-items 区别

一文搞懂flex(弹性盒布局)

5、项目属性(Item)

设置在项目上的属性也有6个。

一文搞懂flex(弹性盒布局)

5.1、order属性:定义项目的排列顺序

数值越小,排列越靠前,默认为0,可以是负值。

.item {
    order: <整数>;
}

一文搞懂flex(弹性盒布局)

5.2、flex-grow属性

flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。

.item{
    flex-grow: <数字>;
}

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

一文搞懂flex(弹性盒布局)

5.3、flex-shrink属性

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。

.item {
  flex-shrink: ; /* default 1 */
}

一文搞懂flex(弹性盒布局)

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

负值对该属性无效。

5.4、align-self属性

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。

.item {
  align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

一文搞懂flex(弹性盒布局)

看到这里,关于 Flex 布局的核心点就介绍得差不多了。掌握好这几个核心的知识点,再去实践练习基本上没有什么太大的问题。剩下一些比较小众的属性,等用到时再去查查看就是了。

6、参考资料

弹性盒子-

https://developer.mozilla.org/zh-CN/docs/Glossary/Flexbox

弹性盒布局-

https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_flexible_box_layout/Basic_concepts_of_flexbox

FlexTest-https://flexbox.help/

Flex 布局教程:语法篇-

https://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

Flexbox 布局的最简单表单-

https://www.ruanyifeng.com/blog/2018/10/flexbox-form.html

【保姆级教程】Vue项目调试技巧-

http://www.guosisoft.com/article/detail/430312211521605

干货|工作中要使用Git,看这篇文章就够了-

http://www.guosisoft.com/article/detail/410508049313861

Vue 前端开发团队风格指南(史上最全)-

http://www.guosisoft.com/article/detail/415491255230533

企业数字化转型如何做?看过来-

http://www.guosisoft.com/article/detail/408745545576517

干货-Vue3 组件通信方式详解-

http://www.guosisoft.com/article/detail/561979982622789

【长文】带你搞明白Redis-

http://www.guosisoft.com/article/detail/558799794786373

免责声明:由于无法甄别是否为投稿用户创作以及文章的准确性,本站尊重并保护知识产权,根据《信息网络传播权保护条例》,如我们转载的作品侵犯了您的权利,请您通知我们,请将本侵权页面网址发送邮件到qingge@88.com,深感抱歉,我们会做删除处理。