参考资料:https://www.bilibili.com/video/BV1Bk4y197xm

一、Grid布局简介

从某种程度上说,grid布局是flex布局的升级版,主要用于元素在平面上的布局,例如我当前博客皮肤主页上每个随笔卡片的排布:

bilibili首页上图片链接的排版:

可以看出,grid布局往往用于在平面上排列元素,而且可以达到不错的效果。

这也是grid布局和flex布局的主要差异,即:

  • flex布局一般用于一个维度排布元素项(item),例如横向或纵向一个方向排布
  • grid布局主要用于在整个平面上(二维)对元素项进行排布,例如单子商城的各个商品项,文章管理系统的各个文章,使用grid布局可以达到非常好的浏览效果。

二、Grid布局的一些概念

和flex布局类似,grid布局也涉及容器元素子元素,我们可能需要在两种元素内都设置相应的css属性才能得到希望的结果。

grid布局中的基本概念如下图所示:

要启用grid布局,和flex布局一样,只需要修改容器元素的displaycss属性为grid即可,如:

.grid-container {
display: grid;
}

三、 容器元素属性

1. grid-template-*

1.1 网格行和列的设置

首先是grid-template-columns,它可以用于设置当前排列元素有多少列以及每列的宽度,例如设置:

.grid-container {
display: grid;
grid-template-columns: 100px 100px 100px;
...
}

这样设置代表排列元素为三列,每列的宽度为100px,效果如下:

同理,我们也可以设置排列元素的行数以及每一行的高度:

.grid-container {
...
grid-template-rows: 100px 100px 100px 100px;
}

调试工具下的效果:

1.2 repeat的使用

像刚才那样设置元素的行列可能会遇到一种麻烦的情况,例如如果列数有10列,那么我们则需要写10次列的宽度,此时我们就可以使用repeat写法进行简化,即:

.grid-container {
grid-template-columns: repeat(3, 100px); /* => 100px 100px 100px */
}

第一个参数是数量,第二个参数是大小。

此外,repeat里的第一个参数也可以设置为auto-fill,这样子元素就会根据父元素的宽度大小进行自适应排列了,例如:

  • 容器宽度为600px

  • 容器宽度为400px

1.3 使用fr

fr可以方便地表示比例关系,和flex布局中给子元素设置flex属性表示自己的占比类似。

例如在这里希望容器分成三列,并且每列等分容器的宽度,那么我们可以这样写:

.grid-container {
grid-template-columns: repeat(3, 1fr);
}

这代表着每行的每个元素都占据一份的剩余空间,因此可以实现三等分的效果:

我们也可以自定义比例,例如:

.grid-container {
grid-template-columns: 1fr 2fr 3fr;
}

可以看出,各列的宽度变成了1:2:3

1.4 auto关键字

例子如下:

.grid-container {
grid-template-columns: 100px auto 100px;
}

此时代表左右两列各占用100px宽度,而中间则自动填充满,这样既是我们前面使用flex布局所得到的三栏布局:

2. row-gap, column-gap

显而易见,这两个属性都是用于设置子元素之间间距的大小的

  • row-gap设置行间距
  • column-gap设置列间距

例如设置行间距:

.grid-container {
...
row-gap: 20px;
}

列间距是类似的,这里不赘述了。

此外还可以直接使用gap来简化两个间距的设置:

.grid-container {
...
gap: 20px;
}

3. grid-auto-flow

这个属性主要用于设置元素是以行优先还是列优先进行排列的,默认为行优先,因此我们进行这样的修改:

.grid-container {
grid-auto-flow: column;
}

效果如下:

dense关键字

例如一些这种情况:

这里1号和2号元素的宽度都比较大,2号元素无法放在1号元素的右边,因此1号元素右边就出现了一个空位,而此时我们希望3号元素能够向上占据这个空位进行紧密的排列,此时我们就可以在grid-auto-flow属性后添加dense关键字:

.grid-container {
grid-auto-flow: row dense;
}

可以看到,此时完成了我们紧密排列的需求。

4. items对齐

4.1 justify-items

这个属性用于设置子元素元素在网格内的水平方向上的对齐。

这个属性即用于设置子元素在规定的网格中是以什么样的方式进行对齐的,具体效果如上图所示,其默认值stretch(拉伸),这也就是为什么我们看到子元素占满了各自的网格

4.2 align-items

同理,这个属性用于设置子元素元素在网格内的垂直方向上的对齐,这里不展开了。

4.3 place-items

这个属性是上面两个属性的简写,即:

.grid-container {
place-items: center center; /* => justify-items:center; align-items: center; */
}

5. content对齐

这里的“整个内容区域”指的是前面红色概念图中的红色方框区域,并不是值整个容器,例如原来的例子中的content为下图绿色边框包围的最外围区域:

因此,这个属性是用于设置content关于整个容器的对齐关系的。

因而我们可以设置整个部分垂直居中和水平居中:

.grid-container {
...
justify-content: center;
align-content: center;
}

其他的对齐方式和flex中展现的类似,在此不再赘述。

6. grid-auto-columns/grid-auto-rows

这两个属性分别用于设置多出来的项目的宽和高:

7. 定义区域

使用方式如下案例所示:

.grid-container {
grid-template-areas:
'a b b'
'a c d'
'a e f';
}

这里区域的命名可以是任意的英文单词,上面代码所对应的实际区域为:

这里只是定义区域,在子元素属性上进行相应的设置可以使该子元素占据某个区域。

四、item(子元素)属性

1. grid-column,grid-row

简写:

.item {
grid-column: 1 / 3;
/*
=> grid-column-start: 1;
grid-column-end: 3;
*/
}

另一种写法:使用span

.item {
grid-column-start: span 2;
}

代码的效果和上面相同。

2. grid-area

如上所述,使用这个属性可以使某个子元素占据在容器元素属性中定义的区域:

.item-1 {
grid-area: a;
}

可以看到,1号元素占据了a区域。

此外,grid-area还可以用于简写上面的item位置设置:

3. 定义单个子元素在网格的对齐方式

CSS学习笔记:grid布局的更多相关文章

  1. CSS 学习笔记 - Flex 布局

    传统布局方式的局限性 传统的网页布局方式,采用 display + position + float 的方式来实现.这种方式,无法实现一些复杂的布局,并且在实现某些布局时,会有一些局限性. 比如,最常 ...

  2. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  3. css学习笔记四

    广州天气变冷了,css学习笔记还是要总结. 总结: 1:几米页面静态页面主要是一列结构头部banner图,mainbody部分放文字内容和图书图片,底部是页面的版权信息 2:腾讯软件中心静态页面制作( ...

  4. CSS学习笔记10 相对定位,绝对定位与固定定位

    文档流中的元素的位置由元素在 (X)HTML 中的位置决定,这就是最原始的普通流,前面讲到的浮动CSS学习笔记08 浮动可以改变元素在文档流中的位置,除了这个我们还可以通过使用CSS的position ...

  5. CSS学习笔记08 浮动

    从CSS学习笔记05 display属性一文中,我们知道div是块元素,会独占一行,即使div的宽度很小,像下面这样 应用display属性的inline属性可以让div与div共享一行,除了这种方法 ...

  6. CSS学习笔记09 简单理解BFC

    引子 在讲BFC之前,先来看看一个例子 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  7. 图文详解前端CSS中的Grid布局,你真的可以5分钟掌握

    前言 网站的布局是一个网站设计的根本,CSS的Grid布局已经成为了未来网站布局的基本方式. 今天这篇文章我们通过图文,一起看看如何自己实现Grid布局方式. CSS 第一个Grid布局 首先我们看看 ...

  8. 2022-07-10 第五小组 pan小堂 css学习笔记

    css学习笔记 什么是 CSS? CSS 指的是层叠样式表* (Cascading Style Sheets) CSS 描述了如何在屏幕.纸张或其他媒体上显示 HTML 元素 CSS 节省了大量工作. ...

  9. HTML+CSS学习笔记 (7) - CSS样式基本知识

    HTML+CSS学习笔记 (7) - CSS样式基本知识 内联式css样式,直接写在现有的HTML标签中 CSS样式可以写在哪些地方呢?从CSS 样式代码插入的形式来看基本可以分为以下3种:内联式.嵌 ...

  10. HTML+CSS学习笔记 (6) - 开始学习CSS

    HTML+CSS学习笔记 (6) - 开始学习CSS 认识CSS样式 CSS全称为"层叠样式表 (Cascading Style Sheets)",它主要是用于定义HTML内容在浏 ...

随机推荐

  1. 终端进程启动失败: shell 可执行文件“C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe”的路径不存在。

    因为某些原因重新安装1了vscode 和node  遇到了两个棘手的问题 ctrl + ~  打开终端提示 " 终端进程启动失败: shell 可执行文件"C:\Windows\S ...

  2. VMware vSphere 7 Update 3 下载

    请访问原文链接:https://sysin.org/blog/vmware-vsphere-7-u3/,查看最新版.原创作品,转载请保留出处. vSphere 7 Update 3 已经宣布可用,即将 ...

  3. DDD领域驱动设计落地实践(十分钟看完,半小时落地)

    一.引子 不知今年吹了什么风,忽然DDD领域驱动设计进入大家视野.该思想源于2003年 Eric Evans编写的"Domain-Driven Design领域驱动设计"简称DDD ...

  4. Serverless 架构下的服务优雅下线实践

    作者 | 行松 阿里巴巴云原生团队 应用发布.服务升级一直是一个让开发和运维同学既兴奋又担心的事情. 兴奋的是有新功能上线,自己的产品可以对用户提供更多的能力和价值:担心的是上线的过程会不会出现意外情 ...

  5. Java爬虫系列四:使用selenium-java爬取js异步请求的数据

    在之前的系列文章中介绍了如何使用httpclient抓取页面html以及如何用jsoup分析html源文件内容得到我们想要的数据,但是有时候通过这两种方式不能正常抓取到我们想要的数据,比如看如下例子. ...

  6. 基于Apache Hudi 的CDC数据入湖

    作者:李少锋 文章目录: 一.CDC背景介绍 二.CDC数据入湖 三.Hudi核心设计 四.Hudi未来规划 1. CDC背景介绍 首先我们介绍什么是CDC?CDC的全称是Change data Ca ...

  7. GitHub README文件生成目录导航

    效果 环境说明 [root@C61 ~]# cat /etc/redhat-release CentOS release 6.10 (Final) [root@C61 ~]# uname -a Lin ...

  8. 并发编程从零开始(八)-ConcurrentHashMap

    并发编程从零开始(八)-ConcurrentHashMap 5.5 ConcurrentHashMap HashMap通常的实现方式是"数组+链表",这种方式被称为"拉链 ...

  9. NOIP模拟84(多校17)

    T1 宝藏 解题思路 考场上一眼出 \(nlog^2\) 做法,然后没看见是 1s 3e5 的数据,我竟然以为自己切了?? 考完之后尝试着把二分改为指针的移动,然后就过了??或许是数据水吧,感觉自己的 ...

  10. DDD领域驱动设计-项目包结构说明-Ⅳ

     基于DDD领域驱动设计的思想,在开发具体系统时,需要先建立不同的层级包.主要是梳理不同层面(应用层,领域层,基础设施层,展示层)包括的功能目录,每一个层面应该包括哪些模块.本例所讲述的分层是DDD落 ...