登录
首页 >  文章 >  前端

flex-grow与flex-shrink如何配合使用

时间:2025-12-06 10:34:24 405浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《flex-grow和flex-shrink如何协同工作》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

flex-grow定义项目在有剩余空间时的扩展比例,默认0不扩展;flex-shrink控制空间不足时的收缩能力,默认1可收缩。两者配合flex-basis可实现精准布局控制,如侧边栏固定宽、主内容区自适应。常见场景中,.sidebar设flex:0 0 200px保持固定,.main设flex:1 1 0填满剩余空间并可压缩。需注意flex-basis对计算起点的影响,避免仅关注grow/shrink而忽略布局偏差。设flex-shrink:0可防止关键元素被压缩,结合媒体查询优化响应式表现。掌握三者协同逻辑能提升布局灵活性与稳定性。

css flex-grow与flex-shrink配合使用

在 CSS Flexbox 布局中,flex-growflex-shrink 是控制弹性项目如何分配容器空间的两个关键属性。它们通常与 flex-basis 一起使用(合称 flex),但在实际开发中,单独调整 grow 和 shrink 能更精细地控制布局行为。

flex-grow 的作用

flex-grow 定义了弹性项目在有剩余空间时,按比例扩展的能力。默认值为 0,表示不扩展。

  • 值为 0:项目不伸展,保持原有尺寸
  • 值为 1 或更大:项目将按比例占据剩余空间
  • 多个项目之间会根据数值比例分配空间,比如一个设为 1,另一个为 2,后者将获得两倍于前者的扩展空间

flex-shrink 的作用

flex-shrink 控制项目在空间不足时是否以及如何收缩。默认值是 1,表示允许收缩。

  • 值为 0:项目不会被压缩,即使内容超出容器
  • 值为 1 或更大:项目可按权重缩小,值越大,缩得越多
  • 当所有项目都设为 flex-shrink: 0 时,可能出现溢出容器的情况

两者配合的实际场景

合理搭配 flex-growflex-shrink 可以实现灵活且健壮的布局。例如在一个侧边栏 + 主内容区的布局中:

.container {
  display: flex;
}
<p>.sidebar {
flex: 0 0 200px; /<em> 不扩展、不收缩、基础宽度200px </em>/
}</p><p>.main {
flex: 1 1 0; /<em> 可扩展、可收缩、基础宽度从0开始 </em>/
}</p>
  • sidebar 固定宽 200px,既不随容器变大而拉伸,也不因容器变小而压缩
  • main 区域会填满剩余空间,同时在屏幕缩小时自动压缩内容区域
  • 这里的 flex: 1 1 0 相当于 flex-grow: 1, flex-shrink: 1, flex-basis: 0

常见误区与建议

使用这两个属性时容易忽略的是 flex-basis 的影响,它决定了计算增长或收缩的起点。

  • 不要只关注 grow/shrink,忽视 basis。比如 flex-basis: 0auto 对空间分配结果差异很大
  • 当希望某个元素“占位但不退让”,设置 flex-shrink: 0 很有效,如固定宽度按钮或标签
  • 在响应式设计中,结合媒体查询动态调整 shrink 值,可以避免小屏下内容被过度挤压

基本上就这些。掌握 flex-grow 与 flex-shrink 的配合逻辑,能让你用更少代码写出更稳定的弹性布局。

好了,本文到此结束,带大家了解了《flex-grow与flex-shrink如何配合使用》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>