深入理解 flex-grow、flex-shrink、flex-basis

目录

1. Flex布局

2. flex-grow

计算方式

3. flex-shrink

计算公式

4. flex-basis

5. 应用场景

6. 总结


1. Flex布局

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性 flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为 0 1 auto

任何一个容器都可以用 Flex 进行布局(如果不会 flex 布局的可见阮老师的 Flex 布局教程),而且 Flex 是发生在父容器和子容器之间的布局关系的,那么父容器与子容器的关系是怎么样子的,又是怎么计算子容器所占用的空间的呢,怎么进行弹性布局的呢?

欲要解决上面的问题,首先得了解 flex-grow 和 flex-shrink 是怎么计算的?flex-basis 和 width 又有什么关系和区别?

接下来,我们先提出两个概念:剩余空间和溢出空间,具体是什么意思我们后面慢慢解释。

2. flex-grow

flex-grow属性在MDN上的定义是:

定义弹性盒子项(flex-item)的拉伸因子,默认值0”

传统的布局是子容器在父容器中从左到右进行布局,应用 flex 进行布局,那么父容器一定设置 display: flex,子容器要“占有”并且“瓜分”父容器的空间,如何占有、瓜分的策略就是弹性布局的策略。这里就要解释到“剩余空间”的概念:

子容器在父容器的“主轴”上还有多少空间可以“瓜分”,这个可以被“瓜分”的空间就叫做剩余空间。

文字总是很抽象,举个例子就能理解剩余空间了,现在有如下的代码:

HTML 代码:

<body>
    <div class="container">
        <div class="item a">
            <p>A</p>
            <p> width:100</p>
            <p>flex-grow:1</p>
        </div>
        <div class="item b">
            <p>B</p>
            <p> width:150</p>
            <p>flex-grow:2</p>
        </div>
        <div class="item c">
            <p>C</p>
            <p> width:100</p>
            <p>flex-grow:3</p>
        </div>
    </div>
</body>

CSS代码:

    <style>
        .container {
            margin: 10px;
            display: flex;
            width: 500px;
            height: 200px;
            background-color: #eee;
            color: #666;
            text-align: center;
        }

        .item {
            height: 100px;
        }

        .item p {
            margin: 0;
        }

        .a {
            width: 100px;
            background-color: #ff4466;
        }

        .b {
            width: 150px;
            background-color: #42b983;
        }

        .c {
            width: 100px;
            background-color: #61dafb;
        }
    </style>

展示的效果如下(最后那个框是截图的时候的标注,不是展示出来的效果):

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端 贾公子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值