css flex属性深入理解

一、flex属性

flex是flex-grow、flex-shrink和flex-basis这三个属性的缩写。 首先来看看这三个属性的定义:

  • flex-grow:该元素获得(伸张)多少正可用空间(positive free space)?
  • flex-shrink:该元素要消除(收缩)多少负可用空间(negative free space)?

该属性用于处理浏览器计算弹性元素的 flex-basis 值,并发现它们太大以至于无法适应弹性容器的情形。只要 flex-shrink 有正值,元素就会收缩以至于它们不会溢出容器。

  • flex-basis:在该元素未伸张和收缩之前,它的大小是多少?

通俗的理解,举个例子:A给5个孩子分财产,总共有300万。

  • flex-grow相当于财产分完有剩余,该如何分配。
  • flex-shrink相当于财产分配不足,该如何分配。
  • flex-basis相当于分配得到的固定财产。

二、flex语法

在Flex布局中,一个Flex子项的宽度是由元素自身尺寸,flex-basis设置的基础尺寸,以及外部填充(flex-grow)或收缩(flex-shrink)规则3者共同决定的。

js 复制代码
flex: none | auto | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
//默认值:flex:0 1 auto
js 复制代码
    flex: auto;
    flex: none;
    /* 1个值,flex-grow */
    flex: 1;
    /* 1个值,flex-basis */
    flex: 100px;
    /* 2个值,flex-grow和flex-basis */
    flex: 1 100px;
    /* 2个值,flex-grow和flex-shrink */
    flex: 1 1;
    /* 3个值 */
    flex: 1 1 100px;

当flex定义为一个或者两个值时,如果是长度值(如:100px),则值flex-basis。

三、flex计算尺寸

3.1 计算尺寸优先级

实际上在Flex布局中,一个flex子项的最终尺寸是基础尺寸、弹性增长或收缩、最大最小尺寸限制共同作用的结果。 其中:

  • 基础尺寸由CSS flex-basis属性,width等属性以及box-sizing盒模型共同决定;
  • 弹性增长指的是flex-grow属性,弹性收缩指的是flex-shrink属性;
  • 最大最小尺寸限制指的是min-width/max-width等CSS属性,以及min-content最小内容尺寸。 最终计算的优先级。
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .container{
            width: 100%;
            background-color: pink;
            display: flex;
        }
       
        .lt{
            flex:0 0 200px;
            background: blue;
            max-width: 100px;
        }
        .ct{
            flex:1 1 auto;
            background: burlywood;
        }
        .rt{
            flex:0 0 200px;
            background: blueviolet;
        }

    </style>
</head>
<body>
    <div class="container">
        <div class="lt box"></div>
        <div class="ct box"></div>
        <div class="rt box"></div>
    </div>
</body>
</html>
复制代码
最大最小尺寸限制 > 弹性增长或收缩 > 基础尺寸

3.2 计算尺寸方式

弹性增长(flex-grow)

css 复制代码
 .container{
    width: 1000px;
    height: 100px;
    display: flex;
}
   
.lt{
    flex:1 0 200px;
    background: blue;
}
.ct{
    flex:2 0 auto;
    background: burlywood;
}
.rt{
    flex:2 0 200px;
    background: blueviolet;
}

总宽度1000px-基本宽度200px-基本宽度200px = 600px

600/5(flexGrow和) = 120

所以计算得到:

  1. lt:120+200px(flex-basis) = 320px;
  2. ct: 120*2 = 240;
  3. rt:120*2+200px(flex-basis) = 440

弹性收缩(flex-shrink)

css 复制代码
  .container{
    width: 1000px;
    height: 100px;
    display: flex;
    background:pink;
}
        
.lt{
    flex:0 1 200px;
    background: blue;
}
.ct{
    flex:0 2 300px;
    background: burlywood;
}
.rt{
    flex:0 3 800px;
    background: blueviolet;
}

分配收缩尺寸与增长尺寸的不同之处:需要计算出收缩的权重和

  1. 首先计算权重之和:flex-shrink*flex-basis相加: 1*200+2*300+3*800 = 3200;
  2. 将上例三个盒子基本宽度相加得到1300px,超出父盒子宽度300px。然后,计算每个盒子的收缩空间:flex-shrink*flex-basis/权重之和
ini 复制代码
lt:200*1/3200*300 = 18.75,故宽度为200-18.75=181.25
ct:300*2/3200*300 = 56.25,故宽度为200-18.75=243.75
rt:800*3/3200*300 = 225,故宽度为800-225=575
相关推荐
kyriewen11 小时前
Sass 进阶:当 CSS 学会了编程,变量函数循环全都安排上
前端·css·scss
清粥油条可乐炸鸡17 小时前
motion入门教程
前端·css·react.js
品克缤19 小时前
解决 SVG 作为 CSS 背景图无法 background-size: 100% 100% 拉伸的问题
前端·css·vue.js·css3
小彭努力中19 小时前
190.Vue3 + OpenLayers 实战:实现地图旋转移动动画 + CSS缩放动画(详解 animate 用法)
前端·css·openlayers·cesium·webgis
HWL567920 小时前
使用CSS实现,带有动态浮动高亮效果的导航菜单
前端·css
天天向上102420 小时前
vue2 div使用css的方式实现自动滚动
前端·javascript·css
@大迁世界20 小时前
3 个 CSS 网格布局,替代你的整个组件库
前端·css
天天向上102421 小时前
vue2 el-table使用css的方式实现列表自动滚动
css·vue.js·elementui
BIBABULALA2 天前
Mini Virtual Machine — 可视化虚拟机模拟器(91行)
前端·css·css3
aXin_li2 天前
从原子化到工程化:Tailwind CSS 的深层价值与实践思考
前端·css