Grid 网格布局

一、概述 

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

Grid 网格布局_第1张图片


Grid 布局与 Flex 布局有一定的相似性,都可以指定容器内部多个项目的位置。但是,它们也存在重大区别。

Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局。Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局。Grid 布局远比 Flex 布局强大。

二、基本概念


1. 容器和项目

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

Grid 网格布局_第2张图片

上面代码中,最外层的
元素就是容器,内层的三个
元素就是项目。

注意:项目只能是容器的顶层子元素,不包含项目的子元素,比如上面代码的

元素就不是项目。Grid 布局只对项目生效。

2.行和列

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

3.单元格

划分网格的线,称为"网格线"(grid line)。水平网格线划分出行,垂直网格线划分出列。

正常情况下,n行有n + 1根水平网格线,m列有m + 1根垂直网格线,比如三行就有四根水平网格线。

Grid 网格布局_第3张图片


三、容器属性


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

display:inline-grid  默认情况下,容器元素都是块级元素,但也可以设成行内元素。

注意,设为网格布局以后,容器子元素(项目)的float、display: inline-block、display: table-cell、vertical-align和column-*等设置都将失效。

grid-template-columns 属性

grid-template-rows 属性

容器指定了网格布局以后,接着就要划分行和列。

grid-template-columns属性定义每一列的列宽,grid-template-rows属性定义每一行的行高。


Grid 网格布局_第4张图片

你可能感兴趣的:(Grid 网格布局)