如何使用CSS Grid?

使用 CSS Grid 核心分两步:先给父容器定义网格规则,再给子项目设置位置或尺寸,3行代码即可实现基础布局。

  1. 定义网格容器(父元素)

给父容器添加 display: grid ,并通过以下属性规划网格结构:

  • grid-template-columns :定义列数和列宽(核心),例如 grid-template-columns: 100px 1fr 2fr 表示"1列固定100px,1列占1份,1列占2份"。

  • grid-template-rows :定义行数和行高,例如 grid-template-rows: 50px auto 表示"1行固定50px,1行自适应内容"。

  • gap :快速设置网格项目间的间距(替代 margin),例如 gap: 10px 。

  1. 控制网格项目(子元素)

无需额外代码,子元素会自动填充网格;也可手动定位:

  • grid-column :控制项目占几列,例如 grid-column: 1 / 3 表示"从第1列开始,到第3列结束(占2列)"。

  • grid-row :控制项目占几行,例如 grid-row: 2 / 4 表示"从第2行开始,到第4行结束(占2行)"。

示例:3列2行网格

/* 父容器:3列(等宽)、2行(50px+自适应)、间距10px */

.grid-container {

display: grid;

grid-template-columns: 1fr 1fr 1fr; /* 3等宽列 */

grid-template-rows: 50px auto; /* 2行 */

gap: 10px;

}

/* 子项目:默认自动填充,也可手动定位 */

.grid-item:nth-child(1) {

grid-column: 1 / 3; /* 第1个项目占前2列 */

}

相关推荐
ZC跨境爬虫39 分钟前
跟着 MDN 学 HTML day_8:(高级文本语义标签+适配核心功底)
前端·css·笔记·ui·html
里欧跑得慢13 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
凯瑟琳.奥古斯特17 小时前
Redis是什么及核心特性
前端·css·redis·缓存
DFT计算杂谈17 小时前
VASP官方教程 TRIQS DFT+DMFT计算教程
运维·css·自动化·html·css3
可达鸭小栈21 小时前
易语言实现CSS像素文字生成器:无需字体文件渲染汉字
前端·css
yqcoder1 天前
CSS 迷思破解:`:nth-child` vs `:nth-of-type`
前端·css
遇见~未来1 天前
第六篇_CSS进阶_深入浏览器与工程化
前端·css·rust
xingpanvip1 天前
星盘接口开发文档:日运语料接口指南
android·开发语言·前端·css·php·lua
之歆1 天前
Day05_CSS完整博客笔记(下)
前端·css·笔记
之歆1 天前
Day05_CSS完整博客笔记(上)
前端·css·笔记