CSS Grid 布局使用教程
2026-04-03 21:44:45
0浏览
收藏
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学习网公众号!
- 下一篇
- Linux一键卸载无用软件及配置清理技巧