当页面结构存在天然行列交叉关系(如仪表盘、卡片网格、表单对齐、侧边栏+主内容布局)时,应优先用 grid;它原生支持二维控制、grid-template-areas 语义清晰、响应式更简洁;而 flex 更适合内联组件(按钮组、导航、表单项)的一维对齐与伸缩。

什么时候该用 grid 而不是 flex
当页面结构天然存在行列交叉关系,比如仪表盘、响应式卡片网格、表单布局(带标签和输入框对齐)、带固定侧边栏+滚动主内容的后台界面,grid 是更直接的选择。它原生支持二维控制——你既能定义列宽,也能定义行高,还能让某个元素横跨多列或多行。flex 本质是一维布局模型,强行用 flex-wrap 模拟二维,容易在对齐、间距、响应断点上反复打补丁。
grid-template-areas 让语义结构一目了然
比起靠 order 和嵌套 flex 容器去调整视觉顺序,grid-template-areas 允许你用字符串“画”出区域布局,HTML 结构可以保持语义自然顺序,CSS 控制呈现位置:
.container {
display: grid;
grid-template-areas:
"header header header"
"sidebar main main"
"footer footer footer";
grid-template-columns: 200px 1fr 1fr;
grid-template-rows: auto 1fr auto;
}
.header { grid-area: header; }
.sidebar { grid-area: sidebar; }
.main { grid-area: main; }
.footer { grid-area: footer; }
这种写法对可维护性帮助很大,尤其当产品频繁调整模块位置时,改几行 CSS 就能重排整个页面骨架,不用动 HTML 或 JS。
别用 grid 替代 flex 做内联对齐或文本流内组件
常见误用:给按钮组、导航菜单、表单项里的 label+input 套一层 display: grid。这反而增加复杂度,且破坏内联流行为。此时 flex 更轻量、兼容性更好、语义更贴切:
立即学习“前端免费学习笔记(深入)”;
-
flex天然适合“一行内多个项目按需伸缩/对齐” -
grid的gap在老版 Safari 中有渲染 bug,而flex的gap支持更稳 - 把
grid用在容器级结构,把flex留给组件内部微调,分工更清晰
响应式重构时,grid 的 minmax() + auto-fit 很实用
替代过去靠媒体查询 + 多套 flex-wrap 规则的做法,用一行 grid-template-columns 就能实现“尽可能多列,但每列不窄于 250px”:
.card-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 1rem;
}
注意:auto-fit 会合并空轨道,auto-fill 则保留空位;真要填满容器宽度,优先选 auto-fit。另外,IE11 不支持 minmax() 和 auto-fit,如果还要兼容,得回退到媒体查询方案。
二维布局不是银弹,关键在分层:大结构用 grid 定骨架,小部件用 flex 做微调。混淆层级,反而让代码更难 debug。










