使用 grid-template 可定义行、列与命名区域,通过 "header header" 60px / 200px 1fr 等语法创建清晰布局,结合 fr、repeat() 和 gap 实现响应式结构。

使用 grid-template 可以高效定义复杂的 CSS 网格布局。它允许你一次性设置行、列和区域,让页面结构更清晰直观。关键在于合理划分网格轨道,并利用命名区域提升可读性。
grid-template 属性详解
grid-template 是一个简写属性,可同时设置:
• grid-template-rows(行高)• grid-template-columns(列宽)
• grid-template-areas(命名区域)
语法格式为:
grid-template: [行] / [列]; 或结合区域使用:
立即学习“前端免费学习笔记(深入)”;
grid-template: [区域定义] / [列宽];
使用命名区域创建复杂布局
通过 grid-template-areas 定义可视化结构,适合仪表盘、后台界面等复杂场景。
示例:实现一个带侧边栏、头部、主内容区和底部的布局
.container {
display: grid;
grid-template:
"header header" 60px
"sidebar main" 1fr
"footer footer" 40px
/ 200px 1fr;
}
.header { grid-area: header; }
.sidebar { grid-area: sidebar; }
.main { grid-area: main; }
.footer { grid-area: footer; }
说明:
• 每行字符串代表网格的一行• 字符串中的名称对应元素的 grid-area
• 最后一个值是行高(如 60px)
• 斜杠后是列宽定义
灵活控制行列尺寸
可以混合使用不同单位来适应内容:
• fr 单位:分配剩余空间(如 1fr, 2fr)• 固定值:px, rem 等
• min-content / max-content:根据内容自动调整
• repeat() 函数:简化重复轨道
例如创建响应式卡片网格:
.grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
嵌套与对齐配合使用
复杂布局常需内外网格协作:
• 子元素也可设为 grid 容器• 使用 justify-items 和 align-items 控制内部对齐
• 配合 gap 设置间距更整洁
添加 gap: 10px; 可避免外边距塌陷问题,让结构更稳定。
基本上就这些。掌握 grid-template 的区域写法和灵活单位搭配,就能应对大多数复杂布局需求,代码也更容易维护。不复杂但容易忽略细节,比如区域名称必须用引号包裹,且每行单词数要一致。










