Bootstrap

flex:1是什么?

flex:1 是什么?

首先 flex: 1; 等同于 flex: 1 1 0;

flex: 1 实际上是三个属性的缩写:flex-grow: 1; flex-shrink: 1 flex-basis: auto;

flex-grow的作用

 flex-grow 的作用是表示在当前元素占多少份的意思。

演示一段代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .content {
            width: 500px;
            display: flex; 
        }
        .box-1 {
            background: aqua;
            flex-grow: 1;
        }
        .box-2 {
            background: pink;
            flex-grow: 1;
        }
    </style>
</head>
<body>
    <div class="content">
        <div class="box-1">box-1</div>
        <div class="box-2">box-2</div>
    </div>
</body>
</html>

示例图: 

这样表示2个子元素各占1份,填充满整个flex的内容

flex-basis的作用

 代码演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .content {
            width: 500px;
            display: flex; 
        }
        .box-1 {
            background: aqua;
            flex-basis: 10%;
        }
        .box-2 {
            background: pink;
            flex-basis: 100px;
        }
    </style>
</head>
<body>
    <div class="content">
        <div class="box-1">box-1</div>
        <div class="box-2">box-2</div>
    </div>
</body>
</html>

示例图:

这边没有设置flex-grow所以默认是flex-grow: 0;

flex-basis表示 flex中的剩余空间的大小。

那么box-1就是占总总宽度(500px)的10%,box-2则占总宽度(500px)的100px;

flex-grow 与 flex-basis 其实类似,区别在于,flex-grow 会填充满整个flex内容,而flex-basis不会通常满整个内容。

flex-shrink的作用

 代码演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .content {
            width: 500px;
            display: flex; 
        }
        .box-1 {
            background: aqua;
            width: 400px;
            flex-shrink: 1;
        }
        .box-2 {
            background: pink;
            width: 200px;
            flex-shrink: 2;
        }
    </style>
</head>
<body>
    <div class="content">
        <div class="box-1">box-1</div>
        <div class="box-2">box-2</div>
    </div>
</body>
</html>

这边设置flex下2个子元素的宽度分别是 400px 和 300px,可以明显的看出已经超出父元素设置的500px。

那么这是flex-shrink就会起到作用,它会根据flex-shrink设置的值进行收缩。

如果flex-shrink设置为0表示当前元素不会进行收缩,flex-shrink的默认值为1;

 flex-shrink的收缩公示(以这个为例):

子元素超出的宽度 * flex-shrink的值 * 子元素宽度 / 总值;

总值的获取(以当前代码为例):1(box-1的flex-shrink值) * 400(box-1的宽度) + 2(box-2的flex-shrink值) * 300(box-2的宽度) = 1000;

以当前代码为例计算:

 子元素超出的值:500 - (400 + 300) = 200;

总值:1 * 400 + 2 * 300 = 1000;

.box-1收缩的宽度:200 * 1 * 400 / 1000 = 80;

.box-2收缩的宽度:200 * 2 * 300 / 1000 = 120;

实际看效果图

 flex下的子元素确实是按照计算出来的宽度进行收缩了。

那么回归正题,flex:1 等于 flex:1 1 0 就很好理解了,默认情况下 flex 等于 flex 0 1 auto。

实际动手敲一遍代码看看效果会发现其实很好理解😆

;