尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

一文搞懂Flex弹性布局空间分配规则

一文搞懂Flex弹性布局空间分配规则
📅 发布时间:2026/6/18 23:49:08
自从Flex布局面世后,基本每个项目我都是使用FLex,特别是小程序端,官方就是主推的Flex布局,相比以前你得费一些周折的布局方式,现在都能轻轻松松实现,用的多但是有一些计算细节其实也是理解不是特别深的,最近在B站看到一个介绍Flex的视频其中说详细讲到 了计算逻辑的内容,感觉干货挺多,特此记录

前情

早期css布局使用最多的就是浮动,后面出了Flex后,就基本抛弃了浮动的使用,基本每个项目起手就是FLex,特别是小程序端,官方就是主推的Flex布局,所以Flex布局在我平时开发中有的非常多,也是非常好用的布局方式,相比以前你得费一些周折的布局方式,现在都能轻轻松松实现,用的多但是有一些计算细节其实也是理解不是特别深的,flex布局中有一个flex复合属性,用于控制弹性盒子子元素尺寸的,分开就是flex-basis+flex-grow+flex-shrink,最近在B站看到一个介绍Flex的视频其中说详细讲到 了计算逻辑的内容,感觉干货挺多,特此记录

各属性功能描述

flex-basis

定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小,它可以设为跟width或height属性一样的值(比如200px),则项目将占据固定空间

.item {flex-basis: <length> | auto; /* 默认值为auto */
}

flex-grow

定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大;如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍

.item {flex-grow: <number>; /* 默认值为 0 */
}

flex-shrink

定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小;如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小,负值对该属性无效

.item {flex-shrink: <number>; /* 默认值为 1 */
}

Flex空间分配逻辑

Flex空间分配的三步法:

第一步计算所有子元素basis的总和

第二步比较容器宽度和总的basis宽度的

第三步计算容器宽度

总的basis小于容器宽度,应用flex-grow

总的basis大于容器宽度,应用flex-shrink

总的basis等于容器宽度,无需伸缩

整个流程图如下:

image

计算公式如下图:

image 1

计算实战

当空间充足时,flex-grow生效,元素尺寸变大一起加大多余的空间

当前项的最终宽度 = basis + (容器宽度-总的basis) * 当前项的grow/总的grow,下面来看一个示例

关键代码如下:

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><meta name="viewport" content="width=device-width"><title>JS Bin</title>
</head>
<body><div class="container"><div class="a">a</div><div class="b">b</div><div class="c">c</div></div>
</body>
</html>
.container{width:600px;height: 168px;display: flex;flex-direction: row;
}
.a{flex:1 1 0;background-color: red;
}
.b{flex:2 1 auto;width: 200px;background-color: green;
}
.c{flex:3 1 100px;background-color: blue;
}

演示地址:https://jsbin.com/fibecijohi/edit?html,css,output

计算解析:

Flex容器container下有三个子项分别为a,b,c

容器的宽度为600

总的basis = 0(a)+200(b)+100(s) = 300

总的grow = 1(a)+2(b)+3(c) = 6

a项的宽度= 0 + (600 - 300) * 1/6 = 50

b项的宽度= 200 + (600 - 300) * 2/6 = 300

c项的宽度= 100 + (600 - 300) *3/6 = 250

PixPin_2025-09-21_17-25-56

当空间不足时,flex-shrink生效,元素尺寸变小一起减小不足的空间

当前项的最终宽度 = basis - (总的basis - 容器宽度) * (当前项的basis * 当前项的sthrink)/(各元素的basic * 各元素的shrink之和),下面来看一个示例

代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
</head>
<body>
<div class="container"><div class="a">a</div><div class="b">b</div><div class="c">c</div>
</div>
</body>
</html>
.container{width:600px;height: 168px;display: flex;flex-direction: row;
}
.a{flex:1 1 200px;background-color: red;
}
.b{flex:1 3 auto;width: 400px;background-color: green;
}
.c{flex:1 2 100px;background-color: blue;
}

演示地址:https://jsbin.com/barihazasi/edit?html,css,js,output

计算解析:

Flex容器container下有三个子项分别为a,b,c

容器的宽度为600

总的basis = 200(a)+400(b)+100(s) = 700

a项的宽度= 200 - (700 - 600) * 1200/(1200 + 3400 + 2100) = 200 - 100 *200/1600 = 187.5

b项的宽度= 400 - (700 - 600) * 3400/(1200 + 3400 + 2100) = 400 - 100 * 1200/1600 = 325

c项的宽度= 100 - (700 - 600) * 2100/(1200 + 3400 + 2100) = 100 - 100 * 200/1600 = 87.5

PixPin_2025-09-21_17-48-04

总结

一直有在用Flex,也大概知道是按比例计算余下多的或少的空间,但并没有深入研究,今天在B站看到详细介绍计算逻辑的视频真的茅塞顿开,计算逻辑总结如下:

  • 一切始于flex-basis:它决定了是进入扩张模式还是收缩模式
  • 空间充足时,分配空间:系统根据flex-grow的比例分配余下空间
  • 空间不足时,压缩空间:系统根据flex-basis和flex-shrink共同决定的权重分梭压缩量

个人知识有限,如果你有更好的解析方法,希望不吝分享,一起学习一起进步

好好学习!天天向上!

相关新闻

  • “小身材的大心脏”——HT-AD3PS-1+ 在成都恒利泰的射频江湖里到底做了什么?
  • AT_agc012_c [AGC012C] Tautonym Puzzle 题目分析
  • 详细介绍:回调函数与错误处理

最新新闻

  • 实木全屋定制哪家专业?临沂本地实木定制品牌综合排行参考 - 新闻快传
  • 用scikit-learn构建可解释的棒球预测模型
  • MPC555/556开发支持:调试模式、开发端口与寄存器详解
  • 2026合肥全域名表变现渠道盘点,连锁奢品行合扬综合实力位居前列 - 开心测评
  • BP Eva 赋能全周期绩效管理,让每轮考核沉淀员工能力成长档案
  • 2026年6月最新劳力士中国官方售后服务热线地址网点及客服电话 - 劳力士服务中心

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号