概述

网格布局(Grid)是最强大的 CSS 布局方案。

它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局。

Grid 布局与 Flex 布局有一定的相似性,都可以指定容器内部多个项目的位置。但是,它们也存在重大区别。Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局。Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局。Grid 布局远比 Flex 布局强大。

基本概念

容器和项目

采用网格布局的区域,称为"容器"(container)。容器内部采用网格定位的子元素,称为"项目"(item)

<div class="container">
<div class="item"><p>1</p></div>
<div class="item"><p>2</p></div>
<div class="item"><p>3</p></div>
</div>

行和列

容器里面的水平区域称为"行"(row),垂直区域称为"列"(column)

单元格

行和列的交叉区域,称为"单元格"(cell),n行和m列会产生n x m个单元格

网格线

划分网格的线,称为"网格线"(grid line)。水平网格线划分出行,垂直网格线划分出列,正常情况下,n行有n + 1根水平网格线,m列有m + 1根垂直网格线

容器属性

display

display: grid指定一个容器采用网格布局。

.container{
display: grid; // 容器元素都是块级元素
// display: inline-grid // 容器元素是行内元素
}

grid-template-columns,grid-template-rows

容器指定了网格布局以后,接着就要划分行和列。grid-template-columns属性定义每一列的列宽,grid-template-rows属性定义每一行的行高

// 三行三列的网格,列宽和行高都是100px
.container {
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
} // 三行三列的网格,列宽和行高都是33.33%
.container {
display: grid;
grid-template-columns: 33.33% 33.33% 33.33%;
grid-template-rows: 33.33% 33.33% 33.33%;
}

repeat()

重复写同样的值非常麻烦,尤其网格很多时。这时,可以使用repeat()函数,简化重复的值,接受两个参数,第一个参数是重复的次数(本例值是3),第二个参数是所要重复的值

// 三行三列的网格,列宽和行高都是33.33%
.container {
display: grid;
grid-template-columns: repeat(3, 33.33%);
grid-template-rows: repeat(3, 33.33%);
} // 三行三列的网格,列宽和行高依次是100px 20px 80px
.container {
display: grid;
grid-template-columns: repeat(3, 100px 20px 80px);
grid-template-rows: repeat(3, 100px 20px 80px);
}

auto-fill 关键字

单元格的大小是固定的,但是容器的大小不确定。如果希望每一行(或每一列)容纳尽可能多的单元格,这时可以使用auto-fill关键字表示自动填充

// 每列宽度100px,然后自动填充,直到容器不能放置更多的列
.container {
display: grid;
grid-template-columns: repeat(auto-fill, 100px);
}

演示示例:https://jsbin.com/pexizusude/edit?html,css,output

fr关键字

为了方便表示比例关系,网格布局提供了fr关键字(fraction 的缩写,意为"片段")。如果两列的宽度分别为1fr2fr,就表示后者是前者的两倍,使用fr的好像是它会按比例占满容器的宽高

// 两个相同宽度的列 行是第二行是第一行的2位高度
.container {
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr 2fr;
}
// 第一列的宽度为150像素,第二列的宽度是第三列的一半
.container {
display: grid;
grid-template-columns: 150px 1fr 2fr;
}

演示示例:https://jsbin.com/rinaxuyeko/edit?html,css,output

minmax()

产生一个长度范围,表示长度就在这个范围之中。它接受两个参数,分别为最小值和最大值。

// 3列,最后一行最小100px最大为1fr
.container {
display: grid;
grid-template-columns: 1fr 1fr minmax(100px, 1fr);
}

演示示例:https://jsbin.com/vamoqaviyi/edit?html,css,output

auto关键字

表示由浏览器自己决定长度

// 3列,最1列和最后1列宽度为100px,中间值占满余下空间
.container {
display: grid;
grid-template-columns: 100px auto 100px;
}

演示示例:https://jsbin.com/zanericiwu/edit?html,css,output

网络线的名称

grid-template-columns属性和grid-template-rows属性里面,还可以使用方括号,指定每一根网格线的名字,方便以后的引用,网格布局为3行 x 3列,因此有4根垂直网格线和4根水平网格线。方括号里面依次是这八根线的名字。网格布局允许同一根线有多个名字,比如[fifth-line row-5]

.container {
display: grid;
grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4];
grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];
}

grid-row-gap,grid-column-gap,grid-gap

grid-row-gap属性设置行与行的间隔(行间距),grid-column-gap属性设置列与列的间隔(列间距),grid-gap属性是grid-column-gapgrid-row-gap的合并简写形式

// 第一种写法
.container {
grid-row-gap: 20px;
grid-column-gap: 20px;
} // 第二种写法
.container {
grid-gap: 20px 20px;
}

根据最新标准,上面三个属性名的grid-前缀已经删除,grid-column-gapgrid-row-gap写成column-gaprow-gapgrid-gap写成gap

grid-area,grid-template-areas

通过grid-area属性来命名网格元素,命名的网格元素可以通过容器的 grid-template-areas 属性来引用。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>grid-area,**grid-template-areas实战**</title>
<style>
.item1 { grid-area: header; }
.item2 { grid-area: menu; }
.item3 { grid-area: main; }
.item4 { grid-area: right; }
.item5 { grid-area: footer; } .grid-container {
display: grid;
grid-template-areas:
'header header header header header header'
'menu main main main right right'
'menu footer footer footer footer footer';
grid-gap: 10px;
background-color: #2196F3;
padding: 10px;
} .grid-container > div {
background-color: rgba(255, 255, 255, 0.8);
text-align: center;
padding: 20px 0;
font-size: 30px;
}
</style>
</head>
<body>
<h1>grid-area 属性</h1>
<p>你可以使用 <em>grid-area</em> 属性来命名网格元素。</p>
<p>命名的网格元素可以通过容器的 grid-template-areas 属性来引用。</p>
<p>网格布局容器,设置 6 行 3 列。</p>
<div class="grid-container">
<div class="item1">Header</div>
<div class="item2">Menu</div>
<div class="item3">Main</div>
<div class="item4">Right</div>
<div class="item5">Footer</div>
</div>
</body>
</html>

演示地址:https://jsbin.com/woyihekifi/edit?html,css,output

注意,区域的命名会影响到网格线。每个区域的起始网格线,会自动命名为区域名-start,终止网格线自动命名为区域名-end。比如,区域名为header,则起始位置的水平网格线和垂直网格线叫做header-start,终止位置的水平网格线和垂直网格线叫做header-end

grid-area属性还可用作grid-row-startgrid-column-startgrid-row-endgrid-column-end的合并简写形式,直接指定项目的位置

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

演示地址:https://jsbin.com/yoximaloji/1/edit?html,css,output

grid-auto-flow

划分网格以后,容器的子元素会按照顺序,自动放置在每一个网格。默认的放置顺序是"先行后列",即先填满第一行,再开始放入第二行。默认值是row,即"先行后列"。也可以将它设成column,变成"先列后行",还可以设成row dense(表示"先行后列",并且尽可能紧密填满,尽量不出现空格)和column dense(表示"先列后行",并且尽量填满空格)。这两个值主要用于,某些项目指定位置以后,剩下的项目怎么自动放置。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
<style>
.container{
display: grid;
margin-bottom: 5px;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
grid-auto-flow: column;
grid-gap: 5px;
}
.container div{
text-align: center;
line-height: 100px;
color:#fff;
background-color: green;
}
</style>
</head>
<body>
<div class="container">
<div>01</div>
<div>02</div>
<div>03</div>
<div>04</div>
<div>05</div>
<div>06</div>
<div>07</div>
<div>08</div>
<div>09</div>
</div>
</body>
</html>

演示示例:https://jsbin.com/cipayifesi/1/edit?html,css,output

justify-items、align-items、place-items

justify-items属性设置单元格内容的水平位置(左中右),align-items属性设置单元格内容的垂直位置(上中下),place-items属性是align-items属性和justify-items属性的合并简写形式

/*
start:对齐单元格的起始边缘。
end:对齐单元格的结束边缘。
center:单元格内部居中。
stretch:拉伸,占满单元格的整个宽度(默认值)
*/
.container {
justify-items: start | end | center | stretch;
align-items: start | end | center | stretch;
} .container {
/* 如果省略第二个值,则浏览器认为与第一个值相等 */
place-items: <align-items> <justify-items>;
}

演示示例:https://jsbin.com/lipatuxilu/1/edit?html,css,output

justify-content 、align-content 、place-content

justify-content属性是整个内容区域在容器里面的水平位置(左中右),align-content属性是整个内容区域的垂直位置(上中下)。place-content属性是align-content属性和justify-content属性的合并简写形式。

/*
start - 对齐容器的起始边框
end - 对齐容器的结束边框
center - 容器内部居中
stretch - 项目大小没有指定时,拉伸占据整个网格容器
space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍
space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔
space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔
*/
.container {
justify-content: start | end | center | stretch | space-around | space-between | space-evenly;
align-content: start | end | center | stretch | space-around | space-between | space-evenly;
} .container {
/*
如果省略第二个值,浏览器就会假定第二个值等于第一个值
*/
place-content: <align-content> <justify-content>;
}

演示示例:https://jsbin.com/nexolijomi/1/edit?html,css,output

项目属性

grid-column-start 、grid-column-end 、grid-row-start 、grid-row-end

单元格项目的位置是可以指定的,具体方法就是指定项目的四个边框,分别定位在哪根网格线,除了指定为第几个网格线,还可以指定为网格线的名字,使用这四个属性,如果产生了项目的重叠,则使用z-index属性指定项目的重叠顺序

  • grid-column-start属性:左边框所在的垂直网格线
  • grid-column-end属性:右边框所在的垂直网格线
  • grid-row-start属性:上边框所在的水平网格线
  • grid-row-end属性:下边框所在的水平网格线
/* 第1个div的左边框是第1根垂直网格线,右边框是第3根垂直网格线,上边框为第2根水平网格线,下边框为第4根网格线, */
.container div:nth-child(1) {
grid-column-start: 1;
grid-column-end: 3;
grid-row-start: 2;
grid-row-end: 4;
} /* 指定为网格线的名字 */
.container div:nth-child(1) {
grid-column-start: header-start;
grid-column-end: header-end;
} /* span关键字,表示"跨越",即左右边框(上下边框)之间跨越多少个网格 */
.container div:nth-child(1) {
grid-column-start: span 2;
}

除了1号项目以外,其他项目都没有指定位置,由浏览器自动布局,这时它们的位置由容器的grid-auto-flow属性决定

演示示例:https://jsbin.com/sugixexilo/edit?html,css,output

grid-column,grid-row

grid-column属性是grid-column-startgrid-column-end的合并简写形式,grid-row属性是grid-row-start属性和grid-row-end的合并简写形式。

/* 用法 */
.item {
grid-column: <start-line> / <end-line>;
grid-row: <start-line> / <end-line>;
} /* 项目item-1占据第一行,从第一根列线到第三根列线 */
.item-1 {
grid-column: 1 / 3;
grid-row: 1 / 2;
}
/* 等同于 */
.item-1 {
grid-column-start: 1;
grid-column-end: 3;
grid-row-start: 1;
grid-row-end: 2;
} /* 可以使用span关键字,表示跨越多少个网格 */
.item-1 {
background: #b03532;
grid-column: 1 / 3;
grid-row: 1 / 3;
}
/* 等同于 */
.item-1 {
background: #b03532;
grid-column: 1 / span 2;
grid-row: 1 / span 2;
}

演示示例:https://jsbin.com/vivuheqivi/1/edit?html,css,output

grid-area

属性指定项目放在哪一个区域,一般配合容器属性grid-template-areas一起使用,详细说明见上面(grid-area,grid-template-areas)讲解说明

justify-self,align-self,place-self

justify-self属性设置单元格内容的水平位置(左中右),跟justify-items属性的用法完全一致,但只作用于单个项目。

align-self属性设置单元格内容的垂直位置(上中下),跟align-items属性的用法完全一致,也是只作用于单个项目

place-self属性是align-self属性和justify-self属性的合并简写形式

/*
start:对齐单元格的起始边缘。
end:对齐单元格的结束边缘。
center:单元格内部居中。
stretch:拉伸,占满单元格的整个宽度(默认值)
*/
.item {
justify-self: start | end | center | stretch;
align-self: start | end | center | stretch;
} /* 如果省略第二个值,place-self属性会认为这两个值相等 */
.item {
place-self: <align-self> <justify-self>;
}

参考博文:https://www.ruanyifeng.com/blog/2019/03/grid-layout-tutorial.html

Grid 网格布局备忘录的更多相关文章

  1. CSS Grid 网格布局全解析

    介绍 CSS Grid(网格) 布局使我们能够比以往任何时候都可以更灵活构建和控制自定义网格. Grid(网格) 布局使我们能够将网页分成具有简单属性的行和列.它还能使我们在不改变任何HTML的情况下 ...

  2. python之tkinter使用-Grid(网格)布局管理器

    # 使用tkinter编写登录窗口 # Grid(网格)布局管理器会将控件放置到一个二维的表格里,主控件被分割为一系列的行和列 # stricky设置对齐方式,参数N/S/W/E分别表示上.下.左.右 ...

  3. CSS Grid网格布局全攻略

    CSS Grid网格布局全攻略 所有奇技淫巧都只在方寸之间. 几乎从我们踏入前端开发这个领域开始,就不停地接触不同的布局技术.从常见的浮动到表格布局,再到如今大行其道的flex布局,css布局技术一直 ...

  4. 【CSS】343- CSS Grid 网格布局入门

    CSS Grid(网格) 布局使我们能够比以往任何时候都可以更灵活构建和控制自定义网格.Grid(网格) 布局使我们能够将网页分成具有简单属性的行和列. 它还能使我们在不改变任何HTML的情况下,使用 ...

  5. grid网格布局使用

    定义 grid布局是指对网页进行划分成一个一个网格,然后根据自己的要求,可以任意组合. 以前写类似的功能,很麻烦,需要写很多的CSS去控制,有了grid就很方便了,可以随意进行组合. 跟flex有很多 ...

  6. 轻松上手CSS Grid网格布局

    今天刚好要做一个好多div格子错落组成的布局,不是田字格,不是九宫格,12个格子这样子,看起来有点复杂.关键的是笔者有点懒,要写那么多div和css真是不想下手啊.多看了两眼,这布局不跟网格挺像吗?c ...

  7. Grid 网格布局详解

    Grid网格布局详解: Grid布局与Flex布局有着一定的相似性,Grid布局是将容器划分成行和列,产生单元格,可以看做是二维布局. 基本概念: 采用网格布局的区域,称为"容器" ...

  8. TKinter布局之grid 网格布局

    1.由于我们的程序大多数都是矩形,因此特别适合于网格 布局,也就是 grid 布局. 2.使用 grid 布局的时候,我们使用 grid 函数,在里面指 定两个参数,用 row 表示行,用 colum ...

  9. Grid 网格布局

    CSS 网格布局(Grid Layout) 是CSS中最强大的布局系统. 这是一个二维系统,这意味着它可以同时处理列和行,不像 flexbox 那样主要是一维系统. 你可以通过将CSS规则应用于父元素 ...

  10. CSS Grid 网格布局教程

    一.概述 网格布局(Grid)是最强大的 CSS 布局方案. 它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局.以前,只能通过复杂的 CSS 框架达到的效果,现在浏览器内置了. 上 ...

随机推荐

  1. Figma 学习笔记 – Frame

    Frame = <div> Frame 就类似 HTML 中的 div, 它和形状 rectangle 特性上蛮相识的, 但是使用场景其实差很多, 所以不要搞错哦. (除了图片很少会用到 ...

  2. LoRaWAN网关价格干穿地板了

    废话不多说,不要998,不要688,以太网版本只要398,4G版本只要498. 先上图片 1.1 产品特点 ◆ 高性能嵌入式硬件平台 ◆ 使用工业级 Cat.1 4G 模块 ◆ 宽压输入 DC 9-2 ...

  3. 如何用VMWARE创建一个Linux虚拟机

    序言 各位好啊,我是会编程的蜗牛,作为java开发者,我们都是需要接触Linux服务器的,一般部署应用都是部署在Linux服务器上的~ 但一般的服务器要么需要购买,要么只是公司里的,那么有没有免费的L ...

  4. 【赵渝强老师】如何分析Java的内存溢出问题

    一.什么是内存溢出? 内存溢出(OOM:out of memory)通俗理解就是内存不够,通常在运行大型软件或游戏时,软件或游戏所需要的内存远远超出了你主机内安装的内存所承受大小,就叫内存溢出. 在J ...

  5. slab分配器正式被弃用,slub成为分配器唯一选择

    在使用slab分配器进行内存分配时,可能会出现以下缺点: 内存碎片化.由于slab分配器需要将内存分成大小相同的块,如果分配不均衡或者对象大小不同,就容易导致内存碎片化. 性能下降.Slab分配器将内 ...

  6. day13-JavaDoc

    JavaDoc JavaDoc命令是用来生成自己API文档的 参数信息 @author 作者名 @version 版本号 @since 指明需要最早使用的jdk版本 @param 参数名 @retur ...

  7. 云原生周刊:优化 Uber 的持续部署丨2024.10.14

    开源项目推荐 Cog Cog 是将机器学习模型打包到容器的工具.可通过配置将机器学习模型所需的环境和依赖,自动打包到容器里方便部署,让你不再为编写 Docker 文件和 CUDA 而痛苦,还能自动启动 ...

  8. KubeSphere v3.3.1 权限控制详解

    作者:周文浩,青云科技研发工程师,KubeSphere Maintainer.热爱云原生,热爱开源,目前负责 KubeSphere 权限控制的开发与维护. KubeSphere 3.3.1 已经发布一 ...

  9. 快速理解和使用stream流

    数据量越大,硬件内核数越多,stream流相比传统for循环速度越快. 原因是stream流是可以并行处理的. 如果要使用stream流,可以直接用flatmap把外层嵌套扁平化,只留下自己需要处理的 ...

  10. IKAnalyzer分词工具的spring boot项目整合代码版

    简介 IK Analyzer是什么呢,一个很轻量的中文分词工具,是基于java开发的轻量级的中文分词工具包.它是以开源项目Luence为主体的,结合词典分词和文法分析算法的中文分词组件.IK有很多版本 ...