CSS Grid布局完全指南:构建复杂布局的利器

CSS Grid布局完全指南:构建复杂布局的利器

大家好,我是蔓蔓。CSS Grid是CSS中最强大的布局系统之一,它可以让我们轻松构建复杂的网格布局。今天我来和大家分享CSS Grid的完整用法。

什么是CSS Grid

Grid vs Flexbox

css 复制代码
/* Flexbox - 一维布局 */
.flex-container {
  display: flex;
  flex-direction: row;
}

/* Grid - 二维布局 */
.grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto;
}

基本概念

css 复制代码
.grid-container {
  display: grid;
  
  /* 定义列 */
  grid-template-columns: 200px 1fr 1fr;
  
  /* 定义行 */
  grid-template-rows: 100px auto 200px;
  
  /* 定义网格线名称 */
  grid-template-columns: [col1-start] 1fr [col1-end col2-start] 1fr [col2-end];
  
  /* 网格间距 */
  gap: 20px; /* 等同于 grid-gap */
  
  /* 简写形式 */
  grid-template: 
    "header header header" 100px
    "sidebar main main" auto
    "footer footer footer" 50px
    / 200px 1fr 1fr;
}

.header {
  grid-area: header;
}

.sidebar {
  grid-area: sidebar;
}

实战案例

响应式网格布局

css 复制代码
/* 基础网格 */
.responsive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
}

/* 复杂布局 */
.page-layout {
  display: grid;
  grid-template-columns: 250px 1fr;
  grid-template-rows: auto 1fr auto;
  grid-template-areas:
    "sidebar header"
    "sidebar main"
    "sidebar footer";
  min-height: 100vh;
}

@media (max-width: 768px) {
  .page-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "header"
      "sidebar"
      "main"
      "footer";
  }
}

等高卡片布局

css 复制代码
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.card {
  display: flex;
  flex-direction: column;
  background: white;
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.card-content {
  flex: 1; /* 填充剩余空间 */
}

.card-footer {
  margin-top: auto;
}

高级技巧

Grid与Flexbox结合

css 复制代码
/* Grid处理整体布局,Flexbox处理内部布局 */
.dashboard {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 20px;
}

.widget {
  display: flex;
  flex-direction: column;
  background: #f5f5f5;
  border-radius: 8px;
  padding: 20px;
}

.widget-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.widget-body {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

网格对齐

css 复制代码
.container {
  display: grid;
  grid-template-columns: repeat(3, 100px);
  grid-template-rows: repeat(3, 100px);
  
  /* 水平对齐 */
  justify-items: start;    /* start | end | center | stretch */
  justify-content: center; /* start | end | center | stretch | space-between | space-around | space-evenly */
  
  /* 垂直对齐 */
  align-items: center;     /* start | end | center | stretch */
  align-content: space-between;
  
  /* 简写 */
  place-items: center center;    /* align-items + justify-items */
  place-content: center space-between; /* align-content + justify-content */
}

网格线定位

css 复制代码
.item {
  /* 使用网格线定位 */
  grid-column-start: 2;
  grid-column-end: 4;
  grid-row-start: 1;
  grid-row-end: 3;
  
  /* 简写 */
  grid-column: 2 / 4;
  grid-row: 1 / 3;
  
  /* span关键字 */
  grid-column: 1 / span 2;
  grid-row: span 3;
  
  /* 命名网格线 */
  grid-column: col-start / col-end;
}

性能优化

css 复制代码
/* 使用subgrid继承父网格 */
.parent {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.child {
  grid-column: span 2;
  display: grid;
  grid-template-columns: subgrid; /* 继承父网格列 */
}

/* 使用dense填充空白 */
.container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-flow: dense; /* 填充空白区域 */
}

/* 避免过度嵌套 */
/* 好:扁平化结构 */
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

/* 不好:嵌套grid */
.grid .grid {
  display: grid;
}

总结

CSS Grid是一个强大的布局工具,掌握它可以让你轻松构建各种复杂布局。记住:

  1. Grid用于二维布局,Flexbox用于一维布局
  2. 使用repeat()和minmax()创建响应式网格
  3. 使用grid-template-areas简化布局定义
  4. 合理结合Grid和Flexbox

技术应当有温度,好的布局能让用户获得更好的体验。

相关推荐
逸模5 小时前
告别熬夜手工整理台账,逸模智能归集实现项目数据自动化存档
大数据·运维·人工智能·笔记·其他·信息可视化·自动化
fanly115 小时前
AgentForge 智能体组件:与云驿插件平台构建全生态化的微服务一体化智能开发引擎
微服务·ai·agent
weixin_397574095 小时前
生产管理和设备管理:制造执行层的AI痛点
人工智能·制造
冬奇Lab5 小时前
Agent 系列(16):工具链设计——让 LLM 用对工具的五个原则
人工智能·llm·agent
冬奇Lab5 小时前
每日一个开源项目(第125篇):taste-skill - 给 AI 装上审美,让前端不再千篇一律
人工智能·开源·agent
Ajie'Blog6 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
SEONIB_Explorer6 小时前
AI SEO 与传统SEO成本对比:哪种更划算?
人工智能
一次旅行6 小时前
AI领域每日资讯报告
人工智能
Python私教6 小时前
Cursor + Claude Code 全流程实战:搭一套生产级 AI 编程工作流(2026 最新版)
人工智能·语言模型·qwen·ollama·本地大模型·大模型部署·deepseek