css grid布局入门

简介

CSS网格布局(又称“网格”),是一种二维网格布局系统。CSS在处理网页布局方面一直作的不是很好。一开始咱们用的是table(表格)布局,而后用float(浮动),position(定位)和inline-block(行内块)布局,可是这些方法本质上是hack,遗漏了不少功能,例如垂直居中。后来出了flexbox盒布局,解决了不少布局问题,可是它仅仅是一维布局,而不是复杂的二维布局,实际上它们(flexbox与grid)能很好的配合使用。css

浏览器支持状况

在咱们开始正式学习Grid布局以前,先看一下can i use上grid布局在各个浏览器下的支持状况是颇有用的,html

clipboard.png

基本概念

要想学好Grid布局的用法,基本概念的介绍是少不了的,虽然看起来比较枯燥。浏览器

网格容器(Grid Container)

经过display属性设置属性值为grid或inline-grid能够建立一个网格容器。网格容器中的全部子元素就会自动变成网格项目(Grid item)函数

网格线(Grid Line)

组成网格线的分界线。它们能够是列网格线(column grid lines),也能够是行网格线(row grid lines)而且居于行或列的任意一侧布局

网格轨道(Grid Track)

两个相邻的网格线之间为网格轨道。你能够认为它们是网格的列或行学习

网格单元(Grid Cell)

两个相邻的列网格线和两个相邻的行网格线组成的是网格单元,它是最小的网格单元flex

网格区(Grid Area)

网格区是由任意数量网格单元组成flexbox

基本属性及做用

一个简单例子

要介绍Grid布局属性,让咱们先从一个简单例子开始:spa

clipboard.png

如上图所示,若是咱们要实现一个3x3的正方形矩阵,用Grid布局要怎么实现?code

<div class="container">
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</div>
.container {
    display: grid;
    width: 200px;
    height: 200px;
    grid-template-rows: repeat(3, 50px);
    grid-template-columns: repeat(3, 50px);
    grid-row-gap: 10px;
    grid-column-gap:10px;
}
.container div {
    background-color: #ccc;
    border: 1px solid #333;
}

如上面代码所示,3x3的矩阵布局,用Grid布局去写,很是简单方便,相对于使用其余布局来讲,Grid布局的优势就显现出来了,那么,接下来就让咱们看看Grid局部中那些经常使用属性:

  • grid-template-rows:指定的每一个值能够建立每行的高度。行高的尺寸能够是任何非负值,长度能够是px、%、em等长度单位的值
  • grid-template-columns:指定的每一个值来建立每列的列宽
  • repeat函数:使用repeat()能够建立重复的网格轨道。这个适用于建立相等尺寸的网格项目和多个网格项目,repeat()接受两个参数:第一个参数定义网格轨道应该重复的次数,第二个参数定义每一个轨道的尺寸
  • grid-column-gap和grid-row-gap属性用来建立列与列,行与行之间的间距,间距(Gap)能够设置任何非负值,长度值能够是px、%、em等单位值。

网格线号码定位

依旧是上面html代码,一个3x3的矩阵,不一样的是此次咱们经过网线号码来定位某一个特定方块。

.container {
    display: grid;
    width: 200px;
    height: 200px;
    grid-template-rows: repeat(3, 50px);
    grid-template-columns: repeat(3, 50px);
}
.container div {
    background-color: #ccc;
    border: 1px solid #333;
    grid-column-start: 2;
    grid-column-end: 3;
    grid-row-start: 2;
    grid-row-end: 3; 
/*  grid-area: 2/2/3/3; */
  }

经过上面的代码咱们能够实现以下效果:

clipboard.png

咱们定位矩阵正中间的小方块显示出来,其他的就不显示了,下面咱们网格线号码定位的那些属性:

  • 每条线是从网格轨道开始,网格的网格线从1开始,每条网格线逐步增长1
  • grid-row-start:表示开始的行网格线序号
  • grid-row-end:表示结束的行网格线序号
  • grid-column-start:表示开始的列网格线序号
  • grid-row-end:表示结束的列网格线序号
  • 若是一个网格项目跨度只有一行或一列,那么grid-row-end和grid-column-end不是必需的
  • grid-area:网格区域,也是用来定位,若是只提供一个值,它指定了grid-row-start和grid-column-start的值。若是提供两个值,第一个值是grid-row-start、grid-column-start的值,第二个值是grid-row-end、grid-column-end的值,二者之间必需要用/隔开。若是指定四个值,第一个值对应grid-row-start,第二个值对应grid-column-start,第三个值对应grid-row-end和第四个值对应grid-column-end

网格区域命名定位网格项目

经过上面的例子,咱们知道了如何用网格线去定位网格项目,接下来咱们将学习如何经过网格区域的命名来定位网格项目,老样子,依旧从一个例子开始:

<div class="container">
    <div class="first"></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</div>
.container {
    display: grid;
    width: 400px;
    height: 400px;
    grid-template-rows: repeat(3, 100px);
    grid-template-columns: repeat(3, 100px);
    grid-template-areas: "header header2 header3" "body body2 body3" "footer footer2 footer3";
}
.container div {
    background-color: #ccc;
    border: 1px solid #333;
}
.container .first {
    grid-row-start: header2;
    grid-row-end: body2;
    grid-column-start: header;
    grid-column-end: header2;
}

clipboard.png

如上述例子看到的,原本是一个3x3的矩阵,可是经过区域命名的方式,将第一个div设置了跨两行两列,接下来让咱们一块儿了解一下网格区域命名定位网格项目的相关属性:

  • 像网格线名称同样,网格区域的名称也可使用grid-template-areas属性来命名。引用网格区域名称也能够设置网格项目位置
  • 设置网格区域的名称应该放置在单引号或双引号内,每一个名称由一个空格符分开。网格区域的名称,每组(单引号或双引号内的网格区域名称)定义了网格的一行,每一个网格区域名称定义网格的一列
  • grid-row-start和grid-row-end经过区域命名分别设置了行开始的位置和结束,grid-column-start和grid-column-end经过区域命名分别设置了列开始的位置和结束位置

总结

这篇文章简单的介绍了一些Grid布局的属性和用法,但没有涉及全部,Grid布局还有不少属性和用法须要本身去探索,经过不一样属性的排列组合,能够发掘不一样的玩法,这不正是布局的魅力吗?
若是你们想要更加全面的了解Grid布局,能够去Mozilla Grid板块去探索发现Grid布局的魅力。这篇文章若是有错误或不严谨的地方,欢迎批评指正,若是喜欢,欢迎点赞收藏

相关文章
相关标签/搜索