摘要:简言网格布局是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。例用属性和定义网格,同时定义网格线名称。例一组区域名称要放在单引号或双引号内,每一个名称之间以空格分隔。例本例中,是通过隐式网
简言
CSS网格布局(Grid)是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。传统的CSS页面布局 一直不够理想。包括table布局、浮动、定位及内联块等方式,从本质上都是Hack的方式,并且遗漏了一些重要的功能(比如:垂直居中)。Flexbox的出现部分解决了上述问题,但Flex布局是为了解决简单的一维布局,适用于页面局部布局。而Grid天然就是为了解决复杂的二维布局而出现的,适用页面的整体布局。在实际工作中,Grid和Flexbox不但不矛盾,而且还能很好的结合使用。做为WEB程序员,我们在页面布局问题上都付出过努力,也将不断探索新的方案。而Grid是第一个专门为布局问题而生的CSS模块,我们有理由对Grid充满期待。
本文包括18个小节,62个实例,完整阅读需要时间20分钟以上。
为了获得最佳的阅体验,可以访问如下格式的教程:
学习CSS网格
1 网格容器将属性 display 值设为 grid 或 inline-grid 就创建了一个网格容器,所有容器直接子结点自动成为网格项目。
1.1 例1grid { display: grid; }
网格项目按行排列,网格项目占用整个容器的宽度。
演示程序
1.1 例2grid { display: inline-grid; }
网格项目按行排列,网格项目宽度由自身宽度决定。
演示程序
2 显示网格属性grid-template-rows和grid-template-columns用于显示定义网格,分别用于定义行轨道和列轨道。
2.1 例3grid { display: grid; grid-template-rows: 50px 100px; }
属性grid-template-rows用于定义行的尺寸,即轨道尺寸。轨道尺寸可以是任何非负的长度值(px,%,em,等)
网格项目1的行高是50px,网格项目2的行高是100px。
因为只定义了两个行高,网格项目3和4的行高取决于其本身的高度。
演示程序
2.2 例4grid { display: grid; grid-template-columns: 90px 50px 120px; }
类似于行的定义,属性grid-template-columns用于定义列的尺寸。
因为定义中只有三列,所以项目4,5,6排在新的一行; 并因为它们位于第1,2,3列的轨道上,所以其宽度等于定义中第1,2,3列轨道的宽度。
网格项目的第1列,第2列,第3列的宽度分别是 90px, 50px 和 120px 。
演示程序
2.3 例5grid { display: grid; grid-template-columns: 1fr 1fr 2fr; }
单位fr用于表示轨道尺寸配额,表示按配额比例分配可用空间。
本例中,项目1占 1/4 宽度,项目2占 1/4 宽度,项目3占 1/2 宽度。
演示程序
2.4 例6grid { display: grid; grid-template-columns: 3rem 25% 1fr 2fr; }
单位fr和其它长度单位混合使用时,fr的计算基于其它单位分配后的剩余空间。
本例中,1fr = (容器宽度 - 3rem - 容器宽度的25%) / 3
演示程序
3 轨道的最小最大尺寸设置函数minmax()用于定义轨道最小/最大边界值。
3.1 例7grid { display: grid; grid-template-rows: minmax(100px, auto); grid-template-columns: minmax(auto, 50%) 1fr 3em; }
函数minmax()接收两个参数:第一个参数表示最小轨道尺寸,第二个参数表示最大轨道尺寸。长度值可以是auto,表示轨道尺寸可以根据内容大小进行伸长或收缩。
本例中,第一行最小高度设置成100px,但是最大高度设置成auto,表示行高可以根据内容伸长超过100px。
本例中,第一列宽度的最大值设置成50%,表示其宽度不能超过整个容器宽度的50%。
演示程序
4 重复的网格轨道函数repeat()用来定义重复的网格轨道,尤其适用于有多个相同项目的情况下。
4.1 例8grid { display: grid; grid-template-rows: repeat(4, 100px); grid-template-columns: repeat(3, 1fr); }
函数repeat()接收两个参数:第一个参数表示重复的次数,第二个参数表示轨道尺寸。
演示程序
4.2 例9grid { display: grid; grid-template-columns: 30px repeat(3, 1fr) 30px; }
函数repeat()可以用在轨道定义列表当中。
本例中,第1列和第5列的宽度是30px。函数repeat()创建了中间3列,每一列宽度都是1fr。
演示程序
5 定义网格间隙属性grid-column-gap 和 grid-row-gap用于定义网格间隙。
网格间隙只创建在行列之间,项目与边界之间无间隙。
5.1 例10grid { display: grid; grid-row-gap: 20px; grid-column-gap: 5rem; }
间隙尺寸可以是任何非负的长度值(px,%,em等)。
演示程序
5.2 例11grid { display: grid; grid-gap: 100px 1em; }
属性grid-gap是grid-row-gap和grid-column-gap的简写形式。
第一个值表示行间隙,第二个值表示列间隙。
演示程序
5.3 例12grid { display: grid; grid-gap: 2rem; }
如只有一个值,则其即表示行间隙,也表示列间隙。
演示程序
6 用网格线编号定位项目网格线本质上是用来表示网格轨道的开始和结束。
每一条网格线编号都以1开始,以1为步长向前编号,其中包括行列两组网格线。
6.1 例13.item1 { grid-row-start: 2; grid-row-end: 3; grid-column-start: 2; grid-column-end: 3; }
这是一个3行2列的网格,即在行上有4条网格线,在列上有3条网格线。项目1利用网格线编号定位在第2行第2列的位置上。
本例中,项目只跨越一行一列,则grid-row-end和grid-column-end的定义可以省略。
演示程序
6.2 例14.item1 { grid-row: 2; grid-column: 3 / 4; }
属性grid-row 是 grid-row-start 和 grid-row-end的简写形式。
属性grid-column 是 grid-column-start 和 grid-column-end的简写形式。
如果只指定一个值,它表示 grid-row/column-start。
如果两个值都指定,第一个表示 grid-row/column-start ,第二个值表示grid-row/column-end。而且你必须用斜杠(/)分隔这两个值。
演示程序
6.3 例15.item1 { grid-area: 2 / 2 / 3 / 3; }
属性grid-area 是 grid-row-start, grid-column-start, grid-row-end 和 grid-column-end的简写形式。
如果四个值都指定,则第一个表示 grid-row-start, 第二个表示 grid-column-start, 第三个表示 grid-row-end ,第四个表示 grid-column-end。
演示程序
7 网格项目跨越行列网格项目默认都占用一行和一列,但可以使用前一节中定位项目的属性来指定项目跨越多行或多列。
7.1 例16.item1 { grid-column-start: 1; grid-column-end: 4; }
通过grid-column-start和grid-column-end属性值的设置,使该网格项目跨越多列。
演示程序
7.2 例17.item1 { grid-row-start: 1; grid-row-end: 4; }
通过grid-row-start和grid-row-end属性值的设置,使该网格项目跨越多行。
演示程序
7.3 例18.item1 { grid-row: 2 / 5; grid-column: 2 / 4; }
简写属性 grid-row 和 grid-column 即能用来定位项目,也能用来使项目跨越多个行列。
演示程序
7.4 例19.item1 { grid-row: 2 / span 3; grid-column: span 2; }
关键字 span 用来指定跨越行或列的数量。
演示程序
8 网格线命名当利用属性grid-template-rows 和 grid-template-columns定义网格时,可以同时定义网格线的名称。网格线名称可以用于定位网格项目。
8.1 例20grid { display: grid; grid-template-rows: [row-1-start] 1fr [row-2-start] 1fr [row-2-end]; grid-template-columns: [col-1-start] 1fr [col-2-start] 1fr [col-3-start] 1fr [col-3-end]; }
用属性grid-template-rows 和 grid-template-columns定义网格,同时定义网格线名称。
为避免混淆,网格线名称应避免使用规范中的关键字(span等)。
定义网格线名称的方法是要将其放在中括号内([name-of-line]),并要和网格轨道相对应。
8.2 例21grid { display: grid; grid-template-rows: [row-start row-1-start] 1fr [row-1-end row-2-start] 1fr [row-2-end row-end]; grid-template-columns: [col-start] 1fr [col-2-start] 1fr [col-3-start] 1fr [col-end]; }
可以给同一网格线定义多个名称,方法就是在中括号内用空格将多个名称分开。
每一个网格线名都可以被引用,以用来定位网格项目。
9 用网格线名定位项目利用命名的网格线,可以很方便地进行项目定位。
9.1 例22.item1 { grid-row-start: row-2-start; grid-row-end: row-end; grid-column-start: col-2-start; grid-column-end: col-end; }
引用网格线名称不用加中括号。
演示程序
9.2 例23.item1 { grid-row: row-2-start / row-end; grid-column: col-2-start / col-end; }
简写属性grid-row 和 grid-column也可以利用网格线名称来定位项目。
演示程序
10 用同名网格线命名和定位项目函数repeat()可以定义同名网格线。这节省了给每条网格都命名的时间。
10.1 例24grid { display: grid; grid-template-rows: repeat(3, [row-start] 1fr [row-end]); grid-template-columns: repeat(3, [col-start] 1fr [col-end]); }
函数repeat()可以用来定义同名网格线。 这样多个网格线拥有相同的名字。
同名网格线会被分配一个位置编号,做为其唯一标识。
10.2 例25.item1 { grid-row: row-start 2 / row-end 3; grid-column: col-start / col-start 3; }
用同名网格线来定位项目时,应注意在网格线名称和编号之间有一个空格。
本例中,项目1的行定位开始于第2条名称是row-start的网格线,结束于第3条名称是row-end的网格线;列定位开始于第1条名称是col-start的网格线,结束于第3条名称是col-start的网格线。
演示程序
11 用网格区域命名和定位项目如同网格线命名,可以用属性grid-template-areas给网格区域命名。网格区域名称可以用来定位网格项目。
11.1 例26grid { display: grid; grid-template-areas: "header header" "content sidebar" "footer footer"; grid-template-rows: 150px 1fr 100px; grid-template-columns: 1fr 200px; }
一组区域名称要放在单引号或双引号内,每一个名称之间以空格分隔。
每一组名称定义一行,每一个名称定义一列。
11.2 例27header { grid-row-start: header; grid-row-end: header; grid-column-start: header; grid-column-end: header; }
网格区域名称可以用在属性grid-row-start, grid-row-end, grid-column-start, 和 grid-column-end的值中,用来定位项目。
11.3 例28footer { grid-row: footer; grid-column: footer; }
网格区域名称也可以用于简写属性grid-row 和 grid-column的值中。
11.4 例29aside { grid-area: sidebar; }
网格区域名称也可以用于简写属性grid-area的值中。
演示程序
12 隐式网格隐式网格用来在显式网格之外定位项目。有时在显示网格中没有足够的空间,或者是要在显示网格之外定位项目就要用到隐式网格。这时可以把这些项目放置在隐式网格中。
隐式网格可以通过属性 grid-auto-rows, grid-auto-columns, 和 grid-auto-flow 来定义。
12.1 例30grid { display : grid; grid-template-rows: 70px; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; }
本例中,只定一个行轨道,因此项目 1 和 2 高 70px 。
第2行轨道有隐式网格自动创建并为项目 3 和 4 分配了空间。 属性grid-auto-rows 定义了隐式网格的行轨道尺寸,即项目3和4的高度是 140px 。
演示程序
12.2 例31grid { display : grid; grid-auto-flow: row; }
缺省的网格布局方向是行的方向(row)。
12.3 例32grid { display : grid; grid-auto-flow: column; }
网格的布局方向可以定义为列的方向(column)。
12.4 例33grid { display : grid; grid-template-columns: 30px 60px; grid-auto-flow: column; grid-auto-columns: 1fr; }
本例中,我们只定义了两个列轨道的尺寸30px 和 60px。
隐式网格中自动创建其它列并给项目3,4,5分配空间;分配的空间尺寸是通过属性 grid-auto-columns定义的。
演示程序
13 隐式命名的网格区域网格线名称可以任意指定,但分配以 -start 和 -end 结尾的名字有额外的益处,这样隐式地创建了具名网格区域,该名称可以用于项目定位。
13.1 例34grid { display : grid; grid-template-rows: [outer-start] 1fr [inner-start] 1fr [inner-end] 1fr [outer-end]; grid-template-columns: [outer-start] 1fr [inner-start] 1fr [inner-end] 1fr [outer-end]; }
本例中,行和列都有名为inner-start 和 inner-end的网格线,它们隐式地给网格区域分派了名称(inner)。
item1 { grid-area: inner; }
这样我们就能够直接使用网格区域名来定位,而不需要再用网格线来定位项目了。
演示程序
14 隐式命名的网格线隐式命名网格线和隐式命名的网格区域的工作原理刚好相反。
14.1 例35grid { display : grid; grid-template-areas: "header header" "content sidebar" "footer footer"; grid-template-rows: 80px 1fr 40px; grid-template-columns: 1fr 200px; }
定义网格区域时隐式的命名了网格线的名称。这些网格线的名称是基于区域名加上-start 或 -end后缀组成的。
14.2 例36item1 { grid-row-start: header-start; grid-row-end: content-start; grid-column-start: footer-start; grid-column-end: sidebar-end; }
本例中,header是通过隐式网格线名称进行定位的。
演示程序
15 层叠网格项目通过项目定位可以使多个项目层叠在一起,属性z-index可以改变层叠项目的层次。
15.1 例37.item-1, .item-2 { grid-row-start: 1; grid-column-end: span 2; } .item-1 { grid-column-start: 1; z-index: 1; } .item-2 { grid-column-start: 2 }
本例中,项目1 和 2 行定位开始于第1条行网格线,并跨越两列。
两个项目都是用网格线编号进行定位。项目1起始于第1条列网格线,项目2起始于第2条列网格线,这使得两个项目在第一行中间列发生层叠。
缺省情况下,项目2将层叠于项目1之上;然而,给项目1设置属性z-index: 1就使得项目1层叠于项目2之上。
演示程序
15.2 例38.overlay { grid-row-start: header-start; grid-row-end: content-end; grid-column-start: content-start; grid-column-end: sidebar-start; z-index: 1; }
本例中,利用在 grid-template-areas 定义中的隐式网格线名称,定位了一个网格项目(overlay),并将层叠于上层。
演示程序
16 网格项目的对齐方式CSS的 盒模型对齐模块 补充了CSS网格的内容,网格项目可以按行或列的轴线方向实现多种对齐方式。
属性justify-items 和 justify-self 以行轴为参照对齐项目,属性align-items 和 align-self 以列轴为参照对齐项目。
属性justify-items 和 align-items 是网格容器的属性,并支持如下这些值:
auto
normal
start
end
center
stretch
baseline
first baseline
last baseline
16.1 例39.grid { grid-template-rows: 80px 80px; grid-template-columns: 1fr 1fr; grid-template-areas: "content content" "content content"; } .item { grid-area: content } .grid { justify-items: start }
在行的轴线起点处对齐。
演示程序
16.2 例40grid { justify-items: center; }
在行的轴线中点处对齐。
演示程序
16.3 例41grid { justify-items: end; }
在行的轴线终点处对齐。
演示程序
16.4 例42grid { justify-items: stretch; }
在行的轴线方向延伸并填满整个区域。stretch是缺省值。
演示程序
16.5 例43grid { align-items: start; }
在列的轴线起点处对齐。
演示程序
16.6 例44grid { align-items: center; }
在列的轴线中点处对齐。
演示程序
16.7 例45grid { align-items: end; }
在列的轴线终点处对齐。
演示程序
16.8 例46grid { align-items: stretch; }
在列的轴线方向延伸并填满整个区域。
演示程序
16.9 例47grid { justify-items: center; align-items: center; }
项目定位于行轴和列轴线的中间位置。
演示程序
17 网格项目的对齐方式2项目可以用属性align-self 和 justify-self定义自己的对齐方式,并支持如下这些属性值:
auto
normal
start
end
center
stretch
baseline
first baseline
last baseline
17.1 例48.item1 { justify-self: start } .item2 { justify-self: center } .item3 { justify-self: end }
属性justify-self 在行的轴线方向定义对齐方式。
演示程序
17.2 例49.item1 { align-self: start } .item2 { align-self: center } .item3 { align-self: end }
属性align-self 在列的轴线方向定义对齐方式。
演示程序
17.3 例50.item1 { justify-self: center align-self: center }
项目1定位在行的轴线和列的轴线的中间位置。
演示程序
18 网格轨道的对齐方式在网格容器中,网格轨道延轴线方向有多种对齐方式。
属性align-content用于定义网格轨道延着行的轴线的对齐方式,而属性justify-content用于定义网格轨道沿着列的轴线的对齐方式。并分别支持如下属性:
normal
start
end
center
stretch
space-around
space-between
space-evenly
baseline
first baseline
last baseline
18.1 例51.grid { width: 100%; height: 300px; grid-template-columns: repeat(4, 45px); grid-template-rows: repeat(4, 45px); grid-gap: 0.5em; justify-content: start; }
列的轨道在行的轴线起点处对齐。start 是缺省值。
演示程序
18.2 例52.grid { justify-content: end; }
列的轨道在行的轴线终点处对齐。
演示程序
18.3 例53.grid { justify-content: center; }
列的轨道在行的轴线中间处对齐。
演示程序
18.4 例54.grid { justify-content: space-around; }
在每一列的两侧平均分配额外空间。
演示程序
18.5 例55.grid { justify-content: space-between; }
在列与列之间平均分配额外的空间。
演示程序
18.6 例56.grid { justify-content: space-evenly; }
在列与列之间及列与边界之间平均分配额外空间。
演示程序
18.7 例57.grid { align-content: start; }
行的轨道在列的轴线起点处对齐,属性start是缺省值。
演示程序
18.8 例58.grid { align-content: end; }
行的轨道在列的轴线终点处对齐。
演示程序
18.9 例59.grid { align-content: center; }
行的轨道在列的轴线中点处对齐。
演示程序
18.10 例60.grid { align-content: space-around; }
每一行的两侧平均分配额外空间。
演示程序
18.11 例61.grid { align-content: space-between; }
在行与行之间平均分配额外空间。
演示程序
18.12 例62.grid { align-content: space-evenly; }
在行与行之间及行与边界之间平均分配额外空间。
演示程序
结语本教程相对全面地介绍了网格的相关内容,但这并不是一个完整的技术文档。想更全面的学习相关内容,推荐访问 Mozilla开发者网络 和 W3C 的网格文档。
由于能力有限,翻译中难免错误较多,还请大家多多谅解!
十分感谢原文作者Jonathan Suh在本文排版设计,示例制作,文字编辑等方面卓越的工作。
为了获得最佳的阅体验,请访问如下排版的教程:
学习CSS网格
英文原版
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/113191.html
摘要:一概述网格布局是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。接下来,我们从网格容器到网格项的各个基本属性来介绍网格布局。例网格项目按行排列,网格项目宽度由自身宽度决定。这时,浏览器会自动生成多余的网格,以便放置项目。 一、概述 CSS网格布局(Grid)是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。 首先来介绍几个概念: 想象一个三行三列的布局,网格...
摘要:一概述网格布局是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。接下来,我们从网格容器到网格项的各个基本属性来介绍网格布局。例网格项目按行排列,网格项目宽度由自身宽度决定。这时,浏览器会自动生成多余的网格,以便放置项目。 一、概述 CSS网格布局(Grid)是一套二维的页面布局系统,它的出现将完全颠覆页面布局的传统方式。 首先来介绍几个概念: 想象一个三行三列的布局,网格...
摘要:最精彩的地方在于所有的响应特性被添加到了一行代码中。基础响应单位栅格布局带来了一个全新的值单位,单位通常简写为,它允许你根据需要将容器拆分为多个块。 原文地址: https://medium.com/free-code-...原文作者: Per Harald Borgen 翻译作者: hanxiansen showImg(https://segmentfault.com/img/re...
摘要:重复网格区域的名称导致内容跨越这些单元格。中间一排将由两个区域,一个是空单元格,一个区域组成。你可以使用任意数量的相邻的点来声明单个空单元格。只要这些点之间没有空隙隔开,他们就代表一个单独的单元格。 CSS Grid 布局是 CSS 中最强大的布局系统。与 flexbox 的一维布局系统不同,CSS Grid 布局是一个二维布局系统,也就意味着它可以同时处理列和行。通过将 CSS 规则应用...
阅读 2892·2021-11-25 09:43
阅读 3593·2021-08-31 09:41
阅读 1197·2019-08-30 15:56
阅读 2072·2019-08-30 15:55
阅读 2895·2019-08-30 13:48
阅读 2781·2019-08-29 15:15
阅读 916·2019-08-29 15:14
阅读 2615·2019-08-28 18:26