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 布局的必备技能。

相关推荐
爱喝白开水a1 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
董世昌411 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone2 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09013 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农3 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king3 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
夏幻灵4 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_4 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝5 小时前
RBAC前端架构-01:项目初始化
前端·架构