使用 CSS Grid 实现响应式布局的核心是结合 Grid 弹性单位 (fr、minmax())、自动填充 / 适配 (auto-fill/auto-fit)和 媒体查询(@media),既能实现「无断点自适应列数」,也能在不同屏幕尺寸下精准控制布局结构。以下是从基础到复杂的完整实现方法和示例:
一、核心原理:响应式 Grid 的关键属性
| 组合 / 属性 | 作用 | 适用场景 |
|---|---|---|
repeat(auto-fill/auto-fit, minmax(最小值, 1fr)) |
自动填充列数,列宽「最小不低于指定值,最大等分剩余空间」 | 自适应卡片网格(无需媒体查询) |
@media + grid-template-columns/rows |
针对不同断点(移动端 / 平板 / 桌面)调整列数 / 行高 | 精准控制不同屏幕的布局结构 |
grid-template-areas + @media |
语义化调整区域排列(如移动端堆叠、桌面端分栏) | 页面整体布局(头部 / 侧边 / 主体) |
二、实战示例(从简单到复杂)
示例 1:无断点自适应卡片网格(最常用)
无需媒体查询,自动根据屏幕宽度调整列数,列宽最小 200px,超出部分等分,适合卡片列表、商品展示等场景。
html
<div class="card-grid">
<div class="card">卡片 1</div>
<div class="card">卡片 2</div>
<div class="card">卡片 3</div>
<div class="card">卡片 4</div>
<div class="card">卡片 5</div>
</div>
<style>
.card-grid {
display: grid;
/* 核心:自动填充列数,列宽最小 200px,最大 1fr */
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
gap: 16px; /* 网格间距 */
padding: 20px;
}
.card {
padding: 24px;
background: #42b983;
color: white;
border-radius: 8px;
}
</style>
效果:
- 屏幕宽度 ≥
200px * 列数 + 间距时,自动增加列数; - 屏幕宽度不足时,自动换行,列宽不小于
200px; - 列数完全由屏幕宽度决定,无需手动写断点。
示例 2:断点可控的响应式网格(精准定制)
如果需要在特定屏幕尺寸下强制固定列数(如移动端 1 列、平板 2 列、桌面 4 列),结合媒体查询实现:
css
.card-grid {
display: grid;
gap: 16px;
padding: 20px;
/* 移动端默认 1 列 */
grid-template-columns: 1fr;
}
/* 平板(≥768px):2 列 */
@media (min-width: 768px) {
.card-grid {
grid-template-columns: repeat(2, 1fr);
}
}
/* 桌面(≥1200px):4 列 */
@media (min-width: 1200px) {
.card-grid {
grid-template-columns: repeat(4, 1fr);
}
}
优势:完全掌控不同断点的列数,适合对布局有强定制需求的场景。
示例 3:响应式页面整体布局(头部 / 侧边 / 主体 / 底部)
通过 grid-template-areas 结合媒体查询,实现「移动端堆叠、桌面端分栏」的经典布局:
html
<div class="page-layout">
<header class="header">头部</header>
<aside class="sidebar">侧边栏</aside>
<main class="content">主体内容</main>
<footer class="footer">底部</footer>
</div>
<style>
.page-layout {
display: grid;
height: 100vh; /* 占满视口高度 */
gap: 10px;
padding: 10px;
box-sizing: border-box;
/* 移动端:1 列,4 行(头部→侧边→主体→底部) */
grid-template-columns: 1fr;
grid-template-rows: 60px 120px 1fr 60px;
grid-template-areas:
"header"
"sidebar"
"content"
"footer";
}
/* 平板(≥768px):2 列,3 行(头部跨列→侧边+主体→底部跨列) */
@media (min-width: 768px) {
.page-layout {
grid-template-columns: 200px 1fr;
grid-template-rows: 60px 1fr 60px;
grid-template-areas:
"header header"
"sidebar content"
"footer footer";
}
}
/* 桌面(≥1200px):调整侧边栏宽度 */
@media (min-width: 1200px) {
.page-layout {
grid-template-columns: 250px 1fr;
}
}
/* 绑定网格区域 */
.header { grid-area: header; background: #42b983; }
.sidebar { grid-area: sidebar; background: #999; }
.content { grid-area: content; background: #eee; }
.footer { grid-area: footer; background: #333; color: white; }
</style>
效果:
- 移动端:所有区域垂直堆叠(头部 → 侧边 → 主体 → 底部);
- 平板 / 桌面:头部和底部跨列,侧边栏和主体左右分栏,桌面端进一步加宽侧边栏。
三、进阶技巧
1. auto-fill vs auto-fit(关键区别)
两者都能自动填充列数,但对「空列」的处理不同:
auto-fill:保留空列的位置(即使无内容),网格总宽度可能小于容器;auto-fit:折叠空列,让现有列自动撑满容器宽度。
css
/* auto-fit 示例(更推荐,空列折叠) */
.card-grid {
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
2. 响应式间距(gap)
结合媒体查询调整不同屏幕的网格间距,提升移动端体验:
css
.card-grid {
gap: 8px; /* 移动端小间距 */
}
@media (min-width: 768px) {
.card-grid {
gap: 16px; /* 平板/桌面更大间距 */
}
}
3. 结合 clamp() 优化列宽
用 clamp() 替代固定最小值,让列宽更灵活(适配不同屏幕密度):
css
.card-grid {
/* 列宽:最小 180px,理想 20% 容器宽度,最大 240px */
grid-template-columns: repeat(auto-fill, minmax(clamp(180px, 20vw, 240px), 1fr));
}
4. 嵌套 Grid 实现多层响应式
网格项可以再作为 Grid 容器,实现更复杂的嵌套响应式:
html
<div class="card-grid">
<div class="card">
<div class="card-content">
<h3>标题</h3>
<p>内容</p>
</div>
</div>
</div>
<style>
.card {
display: grid;
/* 卡片内部响应式:移动端垂直排列,桌面水平排列 */
grid-template-columns: 1fr;
gap: 8px;
}
@media (min-width: 768px) {
.card {
grid-template-columns: 80px 1fr;
}
}
</style>
四、兼容性与注意事项
- 兼容性 :现代浏览器(Chrome/Firefox/Safari/Edge 90+)完全支持,无需前缀;IE11 仅支持旧版语法(
-ms-前缀),一般无需兼容。 - 性能:Grid 是原生 CSS 布局,性能远高于 JS 动态计算列数,放心使用。
- minmax 最小值:建议设置为「移动端友好的宽度」(如 200px),避免列宽过窄。
- 盒模型 :网格容器加
box-sizing: border-box,避免 padding 导致宽度溢出。
总结
CSS Grid 实现响应式布局的核心思路是:
- 简单卡片布局:用
auto-fill/auto-fit + minmax()实现无断点自适应; - 精准定制布局:用
@media调整grid-template-columns/areas; - 复杂页面布局:结合
grid-template-areas实现语义化响应式。
相比 Flex 布局(一维),Grid(二维)更适合复杂的响应式页面结构,且代码更简洁、可控性更强。