CSS 核心知识点 - grid

思维导图

参考网址: https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_grid_layout

一、什么是 grid?

CSS Grid布局是在CSS3规范中引入的一种新的布局方式,旨在解决传统布局方法(如浮动、定位、表格布局)存在的许多问题。CSS Grid布局规范最早由W3C提出,经过多年的发展和标准化,于2017年成为W3C的推荐标准。

二、grid 布局相比 flex 布局有那些方便之处?

Html + Css 核心知识 - flex (超详细)_html flex-CSDN博客

网格布局更为方便

问题场景一:例如想要实现页面内显示多个元素、每个元素大小尺寸间距相同、每行 显示个数固定**、按行** 由左向右排序、且在页面中均匀分布。如下所示

这时候很多人第一时间想到了 flex、单行用flex很方便、多行的话需要进行一些额外运算

复制代码
.father{
      height: 80vh;
      width: 80vw;
      background-color: #f5f5f5;
      display: flex;
      flex-wrap: wrap;
      align-content: start;
      gap: 10px;
    }  
    .son{
      width: calc((100% - 50px) / 6);
      aspect-ratio: 1 / 1; /* 设置宽高比为1:1 */
      border: 1px solid red;
      box-sizing: border-box;
    }

那有没有不用计算的方案呢! grid 这时候就排上的用场了!

复制代码
.father{
      height: 80vh;
      width: 80vw;
      background-color: #f5f5f5;
      display: grid;
      /* grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr; */
      grid-template-columns: repeat(6, 1fr); /* 定义六个等宽的列 */
      align-content: start;
      gap: 10px;
    }  
    .son{
      /* width: calc((100% - 50px) / 6); */
      aspect-ratio: 1 / 1; /* 设置宽高比为1:1 */
      border: 1px solid red;
      box-sizing: border-box;
    }

问题场景二、实现等比例大小不同盒子布局、场景如下

这时候用其他方案处理就比较麻烦了、而 grid 就能很方便处理

复制代码
.father{
      height: 80vh;
      width: 80vw;
      background-color: #f5f5f5;
      display: grid;
      /* grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr; */
      grid-template-columns: repeat(6, 1fr); /* 定义六个等宽的列 */
      align-content: start;
      gap: 10px;
    }  
    .son{
      /* width: calc((100% - 50px) / 6); */
      aspect-ratio: 1 / 1; /* 设置宽高比为1:1 */
      border: 1px solid red;
      box-sizing: border-box;
      min-width: 200px;
    }
    #item1{
      grid-column: 1/3;
      grid-row: 1/3; 
    }
    #item8{
      grid-column: 5/7;
      grid-row: 2/4; 
    }

根据可用空间自动填充列(这点个人觉得非常好用)。

复制代码
.father{
      height: 80vh;
      width: 80vw;
      background-color: #f5f5f5;
      display: grid;
      /* grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr; */
      grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
      align-content: start;
      gap: 10px;
    }  
    .son{
      /* width: calc((100% - 50px) / 6); */
      aspect-ratio: 1 / 1; /* 设置宽高比为1:1 */
      border: 1px solid red;
      box-sizing: border-box;
    }

可以看到宽度是被自动填充到333px

填充到了 359px

相关推荐
浩星2 小时前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫2 小时前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
小村儿2 小时前
连载04-最重要的Skill---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程
_院长大人_2 小时前
Vue + ECharts 实现价格趋势分析图
前端·vue.js·echarts
IT_陈寒3 小时前
Vite的alias配置把我整不会了,原来是这个坑
前端·人工智能·后端
万物得其道者成3 小时前
Cursor 提效实战:我的前端 Prompt、审查 SKILL、MCP 接入完整方法
前端·prompt
酒鼎3 小时前
学习笔记(12-02)事件循环 - 实战案例 —⭐
前端·javascript
Bigger4 小时前
第一章:我是如何剖析 Claude Code 整体架构与启动流程的
前端·aigc·claude
竹林8184 小时前
从“连接失败”到丝滑登录:我用 ethers.js v6 搞定 MetaMask 钱包连接的全过程
前端·javascript
oi..4 小时前
《Web 安全入门|XSS 漏洞原理、CSP 策略与 HttpOnly 防护实践》
前端·网络·测试工具·安全·web安全·xss