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

相关推荐
Apifox9 分钟前
如何在 Apifox 中通过 Runner 运行包含云端数据库连接配置的测试场景
前端·后端·ci/cd
-代号952713 分钟前
【JavaScript】十四、轮播图
javascript·css·css3
树上有只程序猿36 分钟前
后端思维之高并发处理方案
前端
庸俗今天不摸鱼1 小时前
【万字总结】前端全方位性能优化指南(十)——自适应优化系统、遗传算法调参、Service Worker智能降级方案
前端·性能优化·webassembly
黄毛火烧雪下1 小时前
React Context API 用于在组件树中共享全局状态
前端·javascript·react.js
Apifox1 小时前
如何在 Apifox 中通过 CLI 运行包含云端数据库连接配置的测试场景
前端·后端·程序员
一张假钞2 小时前
Firefox默认在新标签页打开收藏栏链接
前端·firefox
高达可以过山车不行2 小时前
Firefox账号同步书签不一致(火狐浏览器书签同步不一致)
前端·firefox
m0_593758102 小时前
firefox 136.0.4版本离线安装MarkDown插件
前端·firefox
掘金一周2 小时前
金石焕新程 >> 瓜分万元现金大奖征文活动即将回归 | 掘金一周 4.3
前端·人工智能·后端