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 份)。

WPS灵犀
WPS灵犀

WPS灵犀是WPS推出的一款AI智能办公和学习助手

下载
  • 避免写 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 后分”的两阶段计算过程。多数错觉来自把它们当成同一种缩放机制。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1019

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

816

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1665

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

395

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1025

2025.04.24

flex教程
flex教程

php中文网为大家带来了flex教程合集,Flex是采用Flex布局的元素,称为Flex容器(flex container),简称"容器",它的所有子元素自动成为容器成员,有三个核心概念: flex项,需要布局的元素;flex容器,其包含flex项;排列方向,这决定了flex项的布局方向。php中文网还为大家带来flex的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

368

2023.06.14

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

24

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

25

2026.03.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

77

2026.02.28

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 39.3万人学习

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

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