CSS Grid 网格布局完整指南:从容器到项目,实战详解

一、什么是 Grid 布局?

Grid 布局(网格布局)是 CSS 中最强大的布局方案之一。它将网页划分为一个个网格,可以任意组合不同的行和列,实现复杂且响应式的布局效果。与 Flex 布局(一维布局)不同,Grid 是二维布局,可以同时控制行和列。

Flex 布局是轴线布局,只能针对项目在轴线上排列;Grid 布局则是将容器划分为单元格,直接控制项目所在区域。

二、基本概念

2.1 容器与项目

三、容器属性详解

3.1 定义网格:grid-template-columns / grid-template-rows

3.5 对齐方式

项目在单元格内的对齐:
整个内容区域在容器内的对齐:

3.6 隐式网格:grid-auto-rows / grid-auto-columns

当项目超出明确定义的网格时,用于设置自动创建的行/列大小。

  • 容器 :采用 display: griddisplay: inline-grid 的元素。

  • 项目 :容器的直接子元素 (注意:不是所有后代元素)。

    2.2 行、列、单元格、网格线

  • :水平的网格区域

  • :垂直的网格区域

  • 单元格:行和列的交叉区域

网格线 :划分网格的线,n 行有 n+1 条水平网格线,m 列有 m+1 条垂直网格线3.2 网格间距:gap3.3 网格区域:grid-template-areas

3.4 自动排列:grid-auto-flow

控制项目自动排列的方向:

  • row(默认):先行后列

  • column:先列后行

  • row dense / column dense:尽量填满空格

  • justify-items:水平对齐(start | end | center | stretch)

  • align-items:垂直对齐

  • place-items: <align-items> <justify-items>

  • justify-content:水平对齐

  • align-content:垂直对齐

  • place-content: <align-content> <justify-content>

四、项目属性

4.1 指定项目位置4.2 指定项目所在区域:grid-area4.3 单个项目对齐:justify-self / align-self / place-self

五、实战示例:经典布局

5.1 两栏布局5.2 十二网格系统5.3 圣杯布局(Header, Main, Sidebar, Footer)六、总结

Grid 布局非常适合构建复杂的、响应式的网页结构,是现代 CSS 布局的必备技能。

相关推荐
AlbertZein3 小时前
新手上手:Rokid 移动端 + 眼镜端最小实践
前端
前端达人3 小时前
「React实战面试题」:React.memo为什么失效了?
前端·javascript·react.js·前端框架·ecmascript
江城开朗的豌豆3 小时前
嘿,别想那么复杂!我的第一个微信小程序长这样
前端·javascript·微信小程序
Irene19913 小时前
URLSearchParams :处理 URL 查询参数的接口
开发语言·前端·javascript
Dontla3 小时前
Web典型路由结构之Next.js (App Router, v13+) )(文件系统驱动的路由:File-based Routing)声明式路由:文件即路由
开发语言·前端·javascript
我不是程序媛lisa3 小时前
前端正确处理“文字溢出”的思路与最佳实践
前端·css3
BigTopOne3 小时前
【Fragment】parentFragmentManager , childFragmentManager 区别是什么? 分别在什么场景使用?
前端
岁月宁静3 小时前
Vue3.5 + SSE 构建高可用 AI 聊天交互层 ——chat.js 模块架构与实现
前端·vue.js·人工智能
~无忧花开~3 小时前
JavaScript学习笔记(十七):ES6生成器函数详解
开发语言·前端·javascript·笔记·学习·es6·js