0

0

css grid布局与计算网格大小_如何使用百分比与fr单位结合设置

P粉602998670

P粉602998670

发布时间:2026-01-12 13:25:31

|

183人浏览过

|

来源于php中文网

原创

混用 % 和 fr 时,百分比列先按容器宽度计算,fr 列再平分剩余空间;顺序影响布局,如 50% 1fr 1fr 中后两列各得剩余空间的 1/2,而非容器的 25%。

css grid布局与计算网格大小_如何使用百分比与fr单位结合设置

grid-template-columns 里混用 % 和 fr 会怎样

百分比和 fr 单位在同一个 grid-template-columns 声明中可以共存,但它们的计算逻辑完全不同:百分比基于网格容器的总宽度,而 fr 基于剩余可用空间(即总宽减去所有固定/百分比列占去的宽度)。这意味着顺序和比例关系直接影响最终布局。

常见错误是以为 50% 1fr 1fr 会让后两列均分剩下 50% 宽度——实际并非如此。浏览器先按 50% 分配第一列,再把**剩余全部空间**(不是“剩下 50%”)交给两个 fr 单元平分。

  • 如果容器宽 1000px,50% 列占 500px,剩余 500px → 两个 1fr 各得 250px
  • 但如果写成 1fr 50% 1fr,浏览器仍先算 50%(500px),再把剩下 500px 分给前后两个 1fr → 各 250px,中间列反而最宽
  • fr 不会“回退”去重新缩放百分比列;它只对明确留出的空白空间起作用

什么时候该用 % + fr 而不是全用 fr

需要某列严格响应容器宽度(比如侧边栏始终占 20%)、其余列弹性填充时,混用才有意义。纯 fr 无法实现“固定比例基准 + 弹性延展”的混合行为。

典型场景:左侧导航栏固定占容器 25%,主内容区自适应,右侧工具栏最小宽度 300px 且不压缩。

立即学习前端免费学习笔记(深入)”;

grid-template-columns: 25% 1fr minmax(300px, 2fr);

这里 25% 锁定左侧比例,1fr 吃掉中间所有剩余空间,minmax(300px, 2fr) 确保右侧至少 300px,超出部分最多拿走剩余空间的 2 份之一(相对于 1fr 的 1 份)。

快剪辑
快剪辑

国内⼀体化视频⽣产平台

下载
  • 避免写 25% 1fr 1fr 期望三等分——第二、三列加起来才占 75%,它们各自只分到 37.5%
  • 百分比列建议放在开头或结尾,中间插百分比容易让后续 fr 可用空间难以预估
  • 若容器本身宽度不固定(如 flex 容器子项),百分比可能因父级收缩而失效,此时应优先考虑 minmax() + fr

fr 单位在不同浏览器中的表现一致性

fr 是 CSS Grid Level 1 标准特性,在 Chrome 57+、Firefox 52+、Safari 10.1+、Edge 16+ 中行为一致,无需前缀。但要注意 Safari 旧版本(grid-template-columns 声明,降级为 block 流式布局。

真正容易出问题的是嵌套 Grid:外层用 %,内层用 fr,而外层容器宽度由 fit-contentmax-content 决定时,内层 fr 的“剩余空间”可能为 0 或意外值。

  • 调试技巧:在 DevTools 中临时把 fr 换成 px(如 1fr → 200px),确认列是否出现——若仍不显示,说明问题不在 fr,而在容器尺寸或 display: grid 是否生效
  • 不要依赖 fr 实现精确像素控制;它本质是分配比例,不是设定宽度
  • 当需要兼容 IE11 时,必须放弃 fr,改用 calc() 模拟,例如 calc((100% - 25%) / 2)

grid-auto-columns 对 fr 和 % 的影响

grid-auto-columns 只作用于**隐式网格轨道**(即超出 grid-template-columns 显式定义列数的内容),它对显式声明中的 %fr 完全无影响。

也就是说,即使你设了 grid-auto-columns: 1fr,也不会让 grid-template-columns: 50% 1fr 中的 50% 列变成弹性;它只管第 3 列、第 4 列……这些没被显式定义的列。

  • 如果你动态插入大量子元素,又没设 grid-template-columns 覆盖足够列数,grid-auto-columns 才会接管
  • 混用单位时,grid-auto-columns 最好也用 frminmax(),避免与显式列产生尺寸冲突
  • 不要试图用 grid-auto-columns: 50% 来“延续”百分比逻辑——它会被当作每个隐式列都占容器 50%,导致重叠或溢出

实际布局中,混用 %fr 的难点不在语法,而在于脑内实时建模“百分比先扣、fr 后分”的两阶段计算过程。多数错觉来自把它们当成同一种缩放机制。

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

509

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

262

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

752

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

537

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

757

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

603

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

559

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

389

2023.08.22

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

9

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 18.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号