CSS Grid 布局使用教程
时间:2026-04-03 21:44:45 408浏览 收藏
CSS Grid 是专为二维布局设计的强大工具,尤其适用于仪表盘、相册网格、表单对齐和响应式卡片墙等需同时控制行列的场景,而非替代 Flexbox 的万能方案;掌握 fr 单位、minmax() 与 auto-fit 搭配 repeat() 的弹性列定义方式,理解从 1 开始且支持负数反向索引的线编号逻辑,并善用浏览器 DevTools 的 Grid 面板(开启线编号与区域高亮)进行可视化调试,才能真正避开常见陷阱、高效构建健壮灵活的网格布局。

Grid 布局适合什么场景
Grid 不是用来替代 flexbox 的,它专为二维布局设计——需要同时控制行和列的场景才该用。比如仪表盘、相册网格、表单对齐、响应式卡片墙。如果只是水平排列几个按钮或垂直堆叠导航项,flexbox 更轻量、语义更清晰。
grid-template-columns 和 grid-template-rows 怎么设才不踩坑
这两个属性决定网格容器的轨道结构,但初学者常误以为写死像素值最稳妥。其实多数真实项目应优先用 fr、minmax() 和 auto-fit 配合 repeat()。
fr是“剩余空间分配单位”,不是固定像素;1fr 2fr表示按 1:2 分配剩余空间,不是 1px 和 2pxminmax(200px, 1fr)能防止列被压缩到过窄,比单纯写1fr更健壮repeat(auto-fit, minmax(300px, 1fr)))是响应式网格核心写法,浏览器会自动计算能放几列,无需媒体查询
/* 推荐:自适应三栏(最小 300px,最多填满) */
.container {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr))));
}grid-column 和 grid-row 的起止线编号容易搞错
Grid 线编号从 1 开始,且默认每条轨道两侧都有一条线。一个 3 列网格有 4 条纵向线(1–4),不是 3 条。用负数可从末尾反向计数:-1 指最右边那条线。
grid-column: 2 / 4表示从第 2 条线开始,到第 4 条线结束(跨两列)grid-column: 1 / -1是常用技巧,让元素横跨全部列,比写1 / 5更安全(列数变化时不用改)- 避免用
span 2直接写在属性里,除非你确定起点明确;grid-column: span 2会从当前源顺序位置开始跨,容易在重排后行为异常
调试 Grid 布局时最该开的 DevTools 设置
Chrome 和 Firefox 的 Grid 面板不是装饰——它能实时显示线编号、轨道尺寸、区域命名,关掉等于蒙眼调样式。
- 右键元素 → “检查” → 右上角三个点 → 勾选
Show line numbers(显示线编号) - 勾选
Highlight areas,带grid-area名称的区域会高亮,方便核对命名是否拼错 - 不要依赖“元素面板里看 computed width/height”来判断 Grid 行高列宽,那些值常是
auto或0px,实际尺寸得看 Grid 面板里的轨道信息
Grid 的复杂度不在语法,而在理解“容器定义轨道、子项定位到轨道”的分离逻辑。很多人卡在子项突然不按预期排列,其实八成是容器没定义好列数,或者用了 grid-column-start 却忘了配 grid-column-end。
今天关于《CSS Grid 布局使用教程》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
158 收藏
-
140 收藏
-
384 收藏
-
165 收藏
-
187 收藏
-
358 收藏
-
323 收藏
-
391 收藏
-
362 收藏
-
131 收藏
-
297 收藏
-
421 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习