news 2026/4/18 5:33:47

CSS 网格布局(Grid Layout)核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CSS 网格布局(Grid Layout)核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解

CSS 网格布局(Grid Layout)是 CSS 中最强大的二维布局系统,专门用于同时处理行和列的布局,相比弹性布局(Flex)(一维布局)更适合复杂的页面结构设计。下面从核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解。

一、核心概念

先理解 Grid 的基础术语,避免后续混淆:

术语说明
网格容器(Grid Container)应用display: grid的父元素,所有直接子元素自动成为网格项
网格项(Grid Item)网格容器的直接子元素(不包含后代元素)
网格轨道(Grid Track)网格的行(row)或列(column),轨道之间的间距叫「网格间距」
网格单元格(Grid Cell)行和列交叉形成的最小单位(类似表格的单元格)
网格线(Grid Line)划分轨道的分隔线(横向 / 纵向,从 1 开始计数,也可负数反向计数)
网格区域(Grid Area)多个相邻单元格组成的矩形区域

二、基础使用(快速上手)

1. 定义网格容器

首先给父元素设置display: grid,将其变为网格容器:

.container{display:grid;/* 块级网格,占满一行 *//* display: inline-grid; 行内网格,宽度由内容决定 */}
2. 定义列和行(核心)

grid-template-columns(列)和grid-template-rows(行)定义轨道尺寸,支持多种单位:

  • 固定单位:pxemrem
  • 相对单位:%fr(剩余空间份数,Grid 专属)
  • 函数:repeat()(重复)、minmax()(最小最大)、auto(自适应)
.container{display:grid;/* 定义 3 列:第一列 100px,第二列 2fr,第三列 1fr */grid-template-columns:100px 2fr 1fr;/* 定义 2 行:第一行 50px,第二行自适应 */grid-template-rows:50px auto;/* 网格间距(行间距 + 列间距,简写) */gap:10px;/* 等价于 row-gap: 10px; column-gap: 10px; */}
3. 重复轨道(repeat 函数)

简化多列 / 多行的重复定义:

.container{display:grid;/* 重复 4 次,每次 1fr → 4 列,每列占 1/4 剩余空间 */grid-template-columns:repeat(4,1fr);/* 重复 2 次「100px 2fr」→ 100px 2fr 100px 2fr */grid-template-columns:repeat(2,100px 2fr);}

三、关键属性(容器 + 项目)

1. 网格容器属性
属性作用常用值
grid-template-columns/rows定义列 / 行尺寸pxfrrepeat()minmax()
gap(row-gap/column-gap)网格间距数值 +px/rem
grid-template-areas命名网格区域自定义名称(如header)、.(空单元格)
justify-items项目在单元格内水平对齐start/center/end/stretch(默认)
align-items项目在单元格内垂直对齐start/center/end/stretch(默认)
place-items简写(垂直 + 水平)center center(先垂直后水平)
justify-content整个网格在容器内水平对齐(网格总尺寸 < 容器时生效)start/center/end/space-between/space-around
align-content整个网格在容器内垂直对齐同上
grid-auto-flow项目自动排列方式row(默认,按行排)、column(按列排)、dense(填充空白)
2. 网格项目属性

(作用于网格容器的直接子元素,精准控制单个项目)

属性作用示例
grid-column-start/end项目占据的列范围(通过网格线)grid-column-start: 1; grid-column-end: 3;(跨 1-3 列)
grid-row-start/end项目占据的行范围grid-row: 2 / 4;(简写,跨 2-4 行)
grid-column/row简写(start /end)grid-column: 1 / span 2;(从第 1 列开始,跨 2 列)
grid-area绑定命名区域 / 简写行列范围grid-area: header;grid-area: 2 / 1 / 4 / 3;
justify-self单个项目水平对齐(覆盖容器justify-itemscenter/end
align-self单个项目垂直对齐(覆盖容器align-itemscenter/end

四、实战示例

示例 1:基础 3 列自适应网格
<divclass="container"><divclass="item">1</div><divclass="item">2</div><divclass="item">3</div><divclass="item">4</div><divclass="item">5</div></div><style>.container{display:grid;grid-template-columns:repeat(3,1fr);/* 3 列等分 */gap:15px;padding:20px;background:#f5f5f5;}.item{padding:20px;background:#42b983;color:white;text-align:center;}</style>
示例 2:经典页面布局(头部 + 侧边 + 主体 + 底部)

grid-template-areas实现语义化布局:

<divclass="layout"><header>头部</header><aside>侧边栏</aside><main>主体内容</main><footer>底部</footer></div><style>.layout{display:grid;height:100vh;/* 占满视口高度 *//* 定义列:侧边 200px,主体自适应 */grid-template-columns:200px 1fr;/* 定义行:头部 60px,主体自适应,底部 60px */grid-template-rows:60px 1fr 60px;/* 命名网格区域 */grid-template-areas:"header header"/* 第一行:header 跨两列 */"aside main"/* 第二行:aside + main */"footer footer";/* 第三行:footer 跨两列 */gap:10px;}header{grid-area:header;background:#42b983;}aside{grid-area:aside;background:#999;}main{grid-area:main;background:#eee;}footer{grid-area:footer;background:#333;color:white;}</style>
示例 3:响应式网格(适配不同屏幕)

结合minmax()auto-fill实现自适应列数:

.container{display:grid;/* auto-fill:自动填充列数;minmax(200px, 1fr):列宽最小 200px,最大 1fr */grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;}

效果:屏幕宽度足够时自动增加列数,不足时自动换行,列宽不小于 200px。

五、进阶技巧

  1. fr 单位的坑fr基于「容器可用空间」(容器宽度 - 列间距 - 固定列宽)分配,而非容器总宽度。

  2. **dense 填充空白:**当项目跨列 / 行导致空白时,加grid-auto-flow: dense自动填充:

    .container{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-flow:dense;/* 填充空白 */}.item-2{grid-column:span 2;/* 跨 2 列 */}
  3. 网格嵌套:网格项可以再作为网格容器,实现多层布局。

  4. 兼容性:现代浏览器(Chrome/Firefox/Safari/Edge)均支持,无需前缀;IE11 仅支持旧版语法(-ms-前缀),一般无需兼容。

六、Grid vs Flex

特性GridFlex
维度二维(行 + 列)一维(行 或 列)
适用场景复杂页面布局、网格卡片、多行列结构单行 / 单列布局(如导航、居中、列表)
核心优势精准控制行列关系,支持区域命名灵活的单行 / 列对齐,适配性强

总结:Grid 是二维布局的首选,适合需要同时控制行和列的场景;Flex 适合一维线性布局。实际开发中可结合使用(如 Grid 做整体布局,Flex 做内部元素对齐)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 11:57:22

技术拆解:中国首款全植入脑机接口的三大核心突破与工程化实践

引言&#xff1a;从工程落地视角看脑机接口的 “中国方案”​2025 年 12 月 13 日&#xff0c;脑虎科技发布国内首款 “全植入、全无线、全功能” 脑机接口产品&#xff0c;首位瘫痪 8 年的受试者实现意念操控游戏、刷视频等复杂交互。对技术开发者而言&#xff0c;这一突破的核…

作者头像 李华
网站建设 2026/4/17 16:48:19

基于stm32的厨房安全检测系统

最近在b站上看到了这个有关stm32的单片机项目&#xff0c;跟着做了一下&#xff0c;以下是原理图和PCB板&#xff0c;因为我是一个嵌入式新手&#xff0c;如果有问题还请大家帮助指正。

作者头像 李华
网站建设 2026/4/18 8:09:20

体系认证和验厂客户的区别

体系认证体系认证是指不同体系制定方授权委托中立的第三方机构对申请通过某种标准的企业是否能达到所规定的标准进行审查的活动。体系审核主要有社会责任审核、质量体系审核、环境体系审核、反恐体系审核等这类标准主要有BSCI、BEPI、SEDEX/SMETA、WRAP、ICTI、WCA、SQP、GMP、…

作者头像 李华
网站建设 2026/4/18 7:57:26

14、Yocto 软件层开发指南

Yocto 软件层开发指南 1. 基础编译示例 1.1 代码示例 以下是一个简单的 C 语言程序编译示例,包含了 helloworld.c 文件和对应的编译、安装脚本: SRC_URI = "file://helloworld.c" S = "${WORKDIR}" do_compile() {${CC} ${LDFLAGS} helloworld.c -…

作者头像 李华
网站建设 2026/4/18 8:31:19

AI 应用外包开发公司

寻找一家优秀的 AI 应用开发公司&#xff0c;其评估标准不同于通用软件外包&#xff0c;更侧重于其数据科学能力、算法工程化、行业定制经验以及快速原型验证能力。以下是从五个关键维度来评估和选择 AI 应用开发公司的专业方法&#xff1a;一、 数据与模型科学能力AI 应用的核…

作者头像 李华