1. 概述
Grid 布局将网页划分成一个个网格,任意组合不同的网格,可以做出各种布局。
1.1 Grid 和 Flex 的差异性
-
相同点
- 两者都可以指定容器内部多个项目的位置。
-
不同点
Flex布局是轴线布局,只能指定项目相对于轴线的位置,是个一维布局。Grid布局是将容器划分成行和列,产生单元格,然后指定项目所在的单元格,是个二维布局。
2. 基本概念
2.1 容器和项目
采用网格布局的区域,称为容器(container)。容器内部采用网格定位的子元素,称为项目(item)。
<div>
<div><p>1</p></div>
<div><p>2</p></div>
<div><p>3</p></div>
</div>
上面代码中,最外层的 <div> 元素就是容器,内层的三个 <div> 元素就是项目。
注意:项目只能是容器的顶层子元素,不包含项目的子元素,比如上面代码的 <p> 元素就不是项目。Grid 布局只对项目生效。
2.2 行和列
容器里面的水平区域称为行(row),垂直区域称为列(column)。
下图:5行5列
2.3 单元格
行和列的交叉区域,称为单元格(cell)。
n行和 m 列会产生 n x m 个单元格。比如,3行3列会产生9个单元格。
2.4 网格线
划分网格的线,称为网格线(grid line)。水平网格线划分出行,垂直网格线划分出列。
n 行有 n + 1 根水平网格线,m 列有 m + 1 根垂直网格线。
下图: 4 x 4 的网格,共有5根水平网格线和5根垂直网格线。
3. 容器属性
定义在容器上面的属性称为容器属性。
3.1 display
指定一个容器采用网格布局。默认情况下,容器元素都是块级元素,但也可以设成行内元素。
display: grid; // 块级元素
display: inline-grid; // 行内元素
注意:设为网格布局以后,容器子元素(项目)的 float、display: inline-block、display: table-cell、vertical-align 和 column-* 等设置都将失效。
display: grid(容器是个块级元素,容器内部采用网格布局):如下图
display: inline-grid(容器是个行内元素,容器内部采用网格布局):如下图
3.2 grid-template-columns、grid-template-rows
定义每一行的行高和每一列的列宽,可以使用绝对单位,也可以使用百分比。
-
grid-template-columns:定义每一列的列宽 -
grid-template-rows:定义每一行的行高下面代码制定了一个三行三列的网格,列宽和列高都是 100px
or33.33%。.container { display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px 100px; } .container { display: grid; grid-template-columns: 33.33% 33.33% 33.33%; grid-template-rows: 33.33% 33.33% 33.33%; }
-
repeat()repeat()接受两个参数,第一个参数是重复的次数,第二个参数是所要重复的值。grid-template-columns: repeat(3, 33.33%); === grid-template-columns: repeat(33.33%, 33.33%, 33.33%); grid-template-columns: repeat(2, 100px 20px 80px); === grid-template-columns: repeat(100px 20px 80px 100px 20px 80px);
-
auto-fill:配合repeat()使用如果单元格的大小是固定的,但是容器的大小不确定,希望每一行(或每一列)容纳尽可能多的单元格,使用
auto-fill关键字表示自动填充。// 表示每列宽度100px,然后自动填充,直到容器不能放置更多的列 grid-template-columns: repeat(auto-fill, 100px); -
fr表示比例关系,网格布局提供了
fr关键字。如果两列的宽度分别为1fr和2fr,表示后者是前者的两倍。fr可以与绝对长度的单位结合使用。grid-template-columns: 1fr 1fr; grid-template-columns: 150px 1fr 2fr; -
minmax()minmax()函数产生一个长度范围,表示长度在这个范围之内。接受两个参数,分别为最小值和最大值。下面代码中,
minmax(100px, 1fr)表示列宽不小于100px,不大于1fr。grid-template-columns: 1fr 1fr minmax(100px, 1fr); -
autoauto表示由浏览器自己决定长度,基本上等于该列单元格的最大宽度grid-template-columns: 100px auto 100px; -
网格线的名称
grid-template-columns属性和grid-template-rows属性里面可以使用方括号,指定每一根网格线的名字,方便以后的引用。.container { display: grid; grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4]; grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4]; }网格布局允许同一根线有多个名字,比如
[fifth-line row-5]。
3.3 grid-row-gap、grid-column-gap、grid-gap
-
grid-row-gap:设置行与行的间隔(行间距) -
grid-column-gap:设置列与列的间隔(列间距) -
grid-gap:grid-column-gap和grid-row-gap的合并简写形式。grid-gap: <grid-row-gap> <grid-column-gap>;.container { grid-row-gap: 20px; grid-column-gap: 20px; } .container { grid-gap: 20px 20px; }
3.4 grid-auto-flow
定义容器子元素自动放置在每一个网格的排列顺序。默认是
row
默认的放置顺序是先行后列。先填满第一行,再开始放入第二行
row:先行后列column:先列后行row dense:先行后列,尽可能紧密填满尽量不出现空格column dense:先列后行,并且尽量填满空格
先行后列: row
先列后行: column
先行后列,尽可能紧密填满尽量不出现空格: row dense
先列后行,并且尽量填满空格: column dense
3.5 justify-items、align-items、place-items
设置单元格内容的对齐方式
-
justify-items:设置单元格内容的水平位置(左中右) -
align-items:设置单元格内容的垂直位置(上中下) -
place-items:这两个的合并简写形式 -
属性值
-
start:对齐单元格的起始边缘 -
end:对齐单元格的结束边缘 -
center:单元格内部居中 -
stretch:拉伸占满单元格的整个宽度(默认值)
place-items: <align-items> <justify-items>;.container { justify-items: start | end | center | stretch; align-items: start | end | center | stretch; } -
3.6 justify-content、align-content、place-content
内容区域在容器里面的位置
-
justify-content:整个内容区域在容器里面的水平位置(左中右) -
align-content:整个内容区域的垂直位置(上中下) -
place-content:这两个的合并简写形式 -
属性值
-
start- 对齐容器的起始边框 -
end- 对齐容器的结束边框 -
center- 容器内部居中 -
stretch- 项目大小没有指定时,拉伸占据整个网格容器 -
space-around- 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍 -
space-between- 项目与项目的间隔相等,项目与容器边框之间没有间隔 -
space-evenly- 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔
place-content: <align-content> <justify-content>;.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; } -
4. 项目属性
定义在项目属性上面的属性称为项目项目属性。
4.1 grid-column-start、grid-column-end、grid-row-start、grid-row-end
指定项目的位置。指定项目所在的四个边框,分别定位在哪根网格线。
-
grid-column-start:左边框所在的垂直网格线 -
grid-column-end:右边框所在的垂直网格线 -
grid-row-start:上边框所在的水平网格线 -
grid-row-end:下边框所在的水平网格线.item-1 { grid-column-start: 1; grid-column-end: 3; grid-row-start: 2; grid-row-end: 4; }
4.2 grid-column、grid-row
grid-column属性是grid-column-start和grid-column-end的合并简写形式
grid-row属性是grid-row-start属性和grid-row-end的合并简写形式
.item {
grid-column: <start-line> / <end-line>;
grid-row: <start-line> / <end-line>;
}
4.3 grid-area
指定项目放在哪一个区域
#container{
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
grid-template-areas: 'a b c'
'd e f'
'g h i';
}
.item-1 {
grid-area: e;
}
上面代码表示:给每一块单元格划分区域并且取了个名字 a ~ i
grid-area: e; 表示把 item-1 放在 e 这个区域里面
grid-area 属性还可用作 grid-row-start、grid-column-start、grid-row-end、grid-column-end 的合并简写形式,直接指定项目的位置。
.item {
grid-area: <row-start> / <column-start> / <row-end> / <column-end>;
}
4.4 justify-self、align-self、place-self
-
justify-self:设置单元格内容的水平位置(左中右),只作用于单个项目 -
align-self:设置单元格内容的垂直位置(上中下),只作用于单个项目 -
place-self:是align-self属性和justify-self属性的合并简写形式place-self: <align-self> <justify-self>; -
属性值
- start:对齐单元格的起始边缘
- end:对齐单元格的结束边缘
- center:单元格内部居中
- stretch:拉伸,占满单元格的整个宽度(默认值)
\