grid网格布局

199 阅读7分钟
1. 概述

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

image.png

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列

img

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根垂直网格线。

img

3. 容器属性

定义在容器上面的属性称为容器属性。

3.1 display

指定一个容器采用网格布局。默认情况下,容器元素都是块级元素,但也可以设成行内元素。

display: grid; // 块级元素
display: inline-grid; // 行内元素

注意:设为网格布局以后,容器子元素(项目)的 floatdisplay: inline-blockdisplay: table-cellvertical-aligncolumn-* 等设置都将失效。

display: grid(容器是个块级元素,容器内部采用网格布局):如下图

img

display: inline-grid(容器是个行内元素,容器内部采用网格布局):如下图

img

3.2 grid-template-columns、grid-template-rows

定义每一行的行高和每一列的列宽,可以使用绝对单位,也可以使用百分比。

  • grid-template-columns:定义每一列的列宽

  • grid-template-rows:定义每一行的行高

    下面代码制定了一个三行三列的网格,列宽和列高都是 100px or 33.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%;
    }
    

img

  • 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);
    

img

  • auto-fill:配合 repeat() 使用

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

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

    img

  • fr

    表示比例关系,网格布局提供了 fr 关键字。如果两列的宽度分别为 1fr2fr ,表示后者是前者的两倍。

    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);
    
  • auto

    auto 表示由浏览器自己决定长度,基本上等于该列单元格的最大宽度

    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-gapgrid-column-gapgrid-row-gap 的合并简写形式。

    grid-gap: <grid-row-gap> <grid-column-gap>;
    
    .container {
      grid-row-gap: 20px;
      grid-column-gap: 20px;
    }
    .container {
      grid-gap: 20px 20px;
    }
    

    img

3.4 grid-auto-flow

定义容器子元素自动放置在每一个网格的排列顺序。默认是 row

默认的放置顺序是先行后列。先填满第一行,再开始放入第二行

  • row:先行后列
  • column :先列后行
  • row dense:先行后列,尽可能紧密填满尽量不出现空格
  • column dense:先列后行,并且尽量填满空格

先行后列: row

img

先列后行: column

img

先行后列,尽可能紧密填满尽量不出现空格: row dense

img

先列后行,并且尽量填满空格: column dense

img

3.5 justify-items、align-items、place-items

设置单元格内容的对齐方式

  • justify-items:设置单元格内容的水平位置(左中右)

  • align-items:设置单元格内容的垂直位置(上中下)

  • place-items:这两个的合并简写形式

  • 属性值

    • start:对齐单元格的起始边缘

      img

    • 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 - 对齐容器的起始边框

      img

    • end - 对齐容器的结束边框

      img

    • center - 容器内部居中

      img

    • stretch - 项目大小没有指定时,拉伸占据整个网格容器

      img

    • space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍

      img

    • space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔

      img

    • space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔

      img

    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;
    }
    

    img

4.2 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>;
}
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 这个区域里面

img

grid-area 属性还可用作 grid-row-startgrid-column-startgrid-row-endgrid-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:拉伸,占满单元格的整个宽度(默认值)

    img

    \