网格布局 CSS Grid

CSS Grid 是 CSS3 提供的二维布局系统,可以同时控制行和列,比 Flexbox(一维布局)更强大,适用于复杂的网页布局设计。

一、Grid 基本概念

1、Grid 容器(Grid Container)

通过 display: grid 或 display: inline-grid 定义一个 Grid 容器:

css 复制代码
.container {
  display: grid;
}
2、Grid 项目(Grid Items)

Grid 容器的直接子元素自动成为 Grid 项目:

html 复制代码
<div class="container">
  <div class="item">Item 1</div>
  <div class="item">Item 2</div>
  <div class="item">Item 3</div>
</div>
3、网格线(Grid Lines)

Grid 布局由行(row)和列(column)组成,网格线是它们的边界线

二、Grid 容器属性

1、定义列和行:grid-template-columns / grid-template-rows
  • grid-template-columns:定义列宽度
  • grid-template-rows:定义行高度

示例:3 列(200px 1fr 200px) + 2 行(100px auto)

css 复制代码
.container {
  display: grid;
  grid-template-columns: 200px 1fr 200px; /* 1fr = 剩余空间 */
  grid-template-rows: 100px auto;
}

单位说明:

复制代码
fr(fraction):剩余空间分配比例

auto:自动调整大小

minmax(min, max):定义最小和最大尺寸
2、定义网格区域:grid-template-areas

通过命名区域布局:

css 复制代码
.container {
  display: grid;
  grid-template-areas:
    "header header header"
    "sidebar main main"
    "footer footer footer";
}
.item-header { grid-area: header; }
.item-sidebar { grid-area: sidebar; }
.item-main { grid-area: main; }
.item-footer { grid-area: footer; }

HTML 结构:

html 复制代码
<div class="container">
  <div class="item-header">Header</div>
  <div class="item-sidebar">Sidebar</div>
  <div class="item-main">Main</div>
  <div class="item-footer">Footer</div>
</div>
3、行列间距:gap(旧版:grid-gap)
复制代码
row-gap:行间距

column-gap:列间距

gap:简写(row-gap column-gap)
css 复制代码
.container {
  gap: 10px 20px; /* 行间距 10px,列间距 20px */
}
4、对齐方式
复制代码
justify-items:所有项目在列方向的对齐(默认 stretch)

    start | end | center | stretch

align-items:所有项目在行方向的对齐(默认 stretch)

    start | end | center | stretch

justify-content:整个网格在容器列方向的对齐

    start | end | center | stretch | space-around | space-between | space-evenly

align-content:整个网格在容器行方向的对齐

三、Grid 项目属性

1、项目位置:grid-column / grid-row
复制代码
grid-column-start / grid-column-end:列起始和结束线

grid-row-start / grid-row-end:行起始和结束线

简写:

    grid-column: <start> / <end>;

    grid-row: <start> / <end>;

示例:跨 2 列 + 跨 3 行

css 复制代码
.item {
  grid-column: 1 / 3; /* 从第 1 列线到第 3 列线 */
  grid-row: 1 / 4;    /* 从第 1 行线到第 4 行线 */
}
2、项目对齐:justify-self / align-self
复制代码
justify-self:单个项目在列方向的对齐

align-self:单个项目在行方向的对齐
css 复制代码
.item {
  justify-self: center;
  align-self: end;
}
3、 项目顺序:order

调整项目的显示顺序(数值越小越靠前):

css 复制代码
.item {
  order: 1;
}
4、Grid 布局示例
1、经典 12 列网格
css 复制代码
.container {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 10px;
}
.item {
  grid-column: span 4; /* 每项占 4 列 */
}
css 复制代码
.container {
  display: grid;
  grid-template-areas:
    "header header header"
    "sidebar main main"
    "footer footer footer";
  grid-template-rows: 80px 1fr 60px;
  grid-template-columns: 200px 1fr;
}
3、自适应卡片布局
css 复制代码
container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 15px;
}
复制代码
auto-fill:自动填充列

minmax(250px, 1fr):最小 250px,最大占剩余空间
5、浏览器兼容性

CSS Grid 已被所有现代浏览器支持(包括 IE11+,但部分语法不同)。可以使用 @supports 检测支持情况:

css 复制代码
@supports (display: grid) {
  .container {
    display: grid;
  }
}
相关推荐
华玥作者25 分钟前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_1 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠1 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
lang201509281 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC2 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务3 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整3 小时前
面试点(网络层面)
前端·网络
VT.馒头3 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
phltxy4 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron07075 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js