Skip to main content

Grid

· One min read
张为杰

Grid 布局

1
2
3
4
5
6
7
8
9
10
11
  1. display: grid 指定一个容器采用网格布局。

  2. grid-template-columns 属性,grid-template-rows 属性

  • 容器指定了网格布局以后,接着就要划分行和列。grid-template-columns 属性定义每一列的列宽,grid-template-rows 属性定义每一行的行高。
  • 除了使用绝对单位,也可以使用百分比。
  1. repeat()

有时候,重复写同样的值非常麻烦,尤其网格很多时。这时,可以使用 repeat()函数,简化重复的值。上面的代码用 repeat()改写如下。

.container {
display: grid;
grid-template-columns: repeat(3, 33.33%);
grid-template-rows: repeat(3, 33.33%);
}
  1. auto-fill 关键字

有时,单元格的大小是固定的,但是容器的大小不确定.自动填充,直到容器不能放置更多的列。

.container {
display: grid;
grid-template-columns: repeat(auto-fill, 100px);
}
  1. fr

网格布局提供了 fr 关键字(fraction 的缩写,意为"片段")。如果两列的宽度分别为 1fr 和 2fr,就表示后者是前者的两倍。

.container {
display: grid;
grid-template-columns: 1fr 1fr;
}
  1. minmax

函数产生一个长度范围,表示长度就在这个范围之中。它接受两个参数,分别为最小值和最大值。

grid-template-columns: 1fr 1fr minmax(100px, 1fr);

上面代码中,minmax(100px, 1fr)表示列宽不小于 100px,不大于 1fr。

  1. auto

auto 关键字表示由浏览器自己决定长度。 grid-template-columns: 100px auto 100px;

  1. 网格线的名称

还可以使用方括号,指定每一根网格线的名字,方便以后的引用。网格布局为 3 行 x 3 列,因此有 4 根垂直网格线和 4 根水平网格线。方括号里面依次是这八根线的名字。

网格布局允许同一根线有多个名字,比如[fifth-line row-5]

.container {
display: grid;
grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4];
grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];
}
  1. 实例:grid-template-columns 属性对于网页布局非常有用。两栏式布局只需要一行代码。

    1. 两栏布局

      .wrapper {
      display: grid;
      grid-template-columns: 70% 30%;
      }
    2. 传统的十二网格布局,写起来也很容易。 grid-template-columns: repeat(12, 1fr);

  2. grid-row-gap 属性设置行与行的间隔(行间距),grid-column-gap 属性设置列与列的间隔(列间距)

img

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

是 grid-column-gap 和 grid-row-gap 的合并简写形式,语法如下。 如果 grid-gap 省略了第二个值,浏览器认为第二个值等于第一个值。

grid-gap: <grid-row-gap> <grid-column-gap>;
.container {
grid-gap: 20px 20px;
}
  1. grid-template-areas (再看看)

网格布局允许指定"区域"(area),一个区域由单个或多个单元格组成。grid-template-areas 属性用于定义区域

  1. grid-auto-flow 属性

划分网格以后,容器的子元素会按照顺序,自动放置在每一个网格。默认的放置顺序是"先行后列",即先填满第一行,再开始放入第二行,即下图数字的顺序 grid-auto-flow:row //即"先行后列" grid-auto-flow:column //即"先列后行" grid-auto-flow: row dense; //表示"先行后列",并且尽可能紧密填满,尽量不出现空格。 grid-auto-flow: column dense; //表示"先列后行",并且尽量填满空格。

grid-auto-flow:row grid-auto-flow:row grid-auto-flow:row dense grid-auto-flow:row dense grid-auto-flow:column dense grid-auto-flow:column dense

  1. justify-content 属性,align-content 属性,place-content 属性

justify-content 属性是整个内容区域在容器里面的水平位置(左中右) align-content 属性是整个内容区域的垂直位置(上中下)

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;
}
  1. justify-items ,align-items ,place-items

justify-items 属性设置单元格内容的水平位置(左中右),align-items 属性设置单元格内容的垂直位置(上中下)。 place-items 属性是 align-items 属性和 justify-items 属性的合并简写形式。 place-items: <align-items> <justify-items>;//如果省略第二个值,则浏览器认为与第一个值相等。

  1. grid-auto-columns ,grid-auto-rows

比如网格只有 3 列,但是某一个项目指定在第 5 行。这时,浏览器会自动生成多余的网格,以便放置项目。grid-auto-columns 属性和 grid-auto-rows 属性用来设置,浏览器自动创建的多余网格的列宽和行高. 一般会有 grid-row-start ,grid-column-start, 这两个属性

.container {
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
grid-auto-rows: 50px;
}```
  1. grid-column-start 属性,grid-column-end 属性,grid-row-start 属性,grid-row-end 属性

    网格线, 是从 1 开始的啊 grid-column-start 属性:左边框所在的垂直网格线 grid-column-end 属性:右边框所在的垂直网格线 grid-row-start 属性:上边框所在的水平网格线 grid-row-end 属性:下边框所在的水平网格线 8

  2. grid-column 属性,grid-row 属性 grid-column 属性是 grid-column-start 和 grid-column-end 的合并简写形式,grid-row 属性是 grid-row-start 属性和 grid-row-end 的合并简写形式

  3. grid-area 属性 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;
    }

    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>;
    }
    .item-1 {
    grid-area: 1 / 1 / 3 / 3;
    }
  4. justify-self 属性,align-self 属性,place-self 属性

    justify-self 属性设置单元格内容的水平位置(左中右),跟 justify-items 属性的用法完全一致,但只作用于单个项目。

    align-self 属性设置单元格内容的垂直位置(上中下),跟 align-items 属性的用法完全一致,也是只作用于单个项目。