前端我爱编程

CSS Grid 布局完全指南2-网格容器(Grid Conta

2018-08-04  本文已影响15人  codeTao

上一篇,介绍了grid的浏览器兼容和重要的几个概念,接下来继续介绍grid的容器属性。

Grid(网格) 属性目录

网格容器(Grid Container) 属性

网格项(Grid Items) 属性

父元素 网格容器(Grid Container) 属性


display

将元素定义为网格容器,并为其内容建立新的 网格格式上下文

值:

如果你想要设置为网格容器元素本身已经是网格项(嵌套网格布局),用这个属性指明这个容器内部的网格项的行列尺寸直接继承其父级的网格容器属性。

.container {
    display: grid | inline-grid | subgrid;
}

注意:在 网格容器(Grid Container) 上使用columnfloatclearvertical-align 不会产生任何效果。

grid-template-columns / grid-template-rows

使用空格分隔的值列表,用来定义网格的列和行。这些值表示 网格轨道(Grid Track) 大小,它们之间的空格表示网格线。

值:
– <track-size>: 可以是长度值,百分比,或者等份网格容器中可用空间(使用 fr 单位)
– <line-name>:你可以选择的任意名称

.container {
    grid-template-columns: <track-size> ... | <line-name> <track-size> ...;
    grid-template-rows: <track-size> ... | <line-name> <track-size> ...;
}

示例:

当你在 网格轨道(Grid Track) 值之间留出空格时,网格线会自动分配数字名称:

.container{
    grid-template-columns: 40px 50px auto 50px 40px;
    grid-template-rows: 25% 100px auto;
}
分隔线名称

但是你可以明确的指定网格线(Grid Line)名称,即 <line-name> 值。请注意网格线名称的括号语法:

.container {
    grid-template-columns: [first] 40px [line2] 50px [line3] auto [col4-start] 50px [five] 40px [end];
    grid-template-rows: [row1-start] 25% [row1-end] 100px [third-line] auto [last-line];
}
分隔线名称

请注意,一条网格线(Grid Line)可以有多个名称。例如,这里的第二条 行网格线(row grid lines) 将有两个名字:row1-end 和row2-start :

.container{
    grid-template-rows: [row1-start] 25% [row1-end row2-start] 25% [row2-end];
}

如果你的定义包含多个重复值,则可以使用 repeat() 表示法来简化定义:

.container {
    grid-template-columns: repeat(3, 20px [col-start]) 5%;
}

上面的代码等价于:

.container {
    grid-template-columns: 20px [col-start] 20px [col-start] 20px [col-start] 5%;
}

fr 单元允许你用等分网格容器剩余可用空间来设置 网格轨道(Grid Track) 的大小 。例如,下面的代码会将每个网格项设置为网格容器宽度的三分之一:

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

剩余可用空间是除去所有非灵活网格项之后计算得到的。在这个例子中,可用空间总量减去 50px 后,再给 fr 单元的值3等分:

.container {
    grid-template-columns: 1fr 50px 1fr 1fr;
}

grid-template-areas

通过引用 grid-area 属性指定的 网格区域(Grid Area) 名称来定义网格模板。重复网格区域的名称导致内容跨越这些单元格。一个点号(.)代表一个空的网格单元。这个语法本身可视作网格的可视化结构。

值:

.container {
  grid-template-areas: 
    " | . | none | ..."
    "...";
}

示例:

.item-a {
  grid-area: header;
}
.item-b {
  grid-area: main;
}
.item-c {
  grid-area: sidebar;
}
.item-d {
  grid-area: footer;
}
 
.container {
  grid-template-columns: 50px 50px 50px 50px;
  grid-template-rows: auto;
  grid-template-areas: 
    "header header header header"
    "main main . sidebar"
    "footer footer footer footer";
}

上面的代码将创建一个 4 列 3 行的网格。整个顶行将由 header 区域 组成。中间一排将由两个 main 区域,一个是空单元格,一个 sidebar 区域组成。最后一行全是 footer 区域组成。

网格区域名称模板

你的声明中的每一行都需要有相同数量的单元格。

你可以使用任意数量的相邻的 点. 来声明单个空单元格。 只要这些点.之间没有空隙隔开,他们就表示一个单一的单元格。

注意你 不是 用这个语法来命名网格线,只是命名网格区域。当你使用这种语法时,区域两端的网格线实际上是自动命名的。如果你的网格区域的名字是 foo,该区域的起始 行网格线 和起始 列网格线 的名称将是 foo-start,而最后一行 行网格线 和最后一列 列网格线 的名字是 foo-end。这意味着一些网格线可能有多个名字,如上例中最左边的网格线,它将有三个名称:header-start,main-start 和 footer-start 。

grid-template

用于定义 grid-template-rowsgrid-template-columnsgrid-template-areas 缩写 (shorthand) 属性。

值:

.container {
  grid-template: none | subgrid | <grid-template-rows> / <grid-template-columns>;
}

这个属性也接受一个更复杂但相当方便的语法来指定三个上诉属性。这里有一个例子:

.container {
  grid-template:
    [row1-start] "header header header" 25px [row1-end]
    [row2-start] "footer footer footer" 25px [row2-end]
    / auto 50px auto;
}

等价于:

.container {
  grid-template-rows: [row1-start] 25px [row1-end row2-start] 25px [row2-end];
  grid-template-columns: auto 50px auto;
  grid-template-areas: 
    "header header header" 
    "footer footer footer";
}

由于 grid-template不会重置 隐式 网格属性(grid-auto-columnsgrid-auto-rows, 和 grid-auto-flow),
这可能是你想在大多数情况下做的,建议使用 grid属性而不是 grid-template

grid-column-gap / grid-row-gap

指定网格线(grid lines)的大小。你可以把它想象为设置列/行之间间距的宽度。

值:

.container {
  grid-column-gap: <line-size>;
  grid-row-gap: <line-size>;
}

示例:

.container {
  grid-template-columns: 100px 50px 100px;
  grid-template-rows: 80px auto 80px; 
  grid-column-gap: 10px;
  grid-row-gap: 15px;
}
网格单元间距

只能在 列/行 之间创建间距,网格外部边缘不会有这个间距。

grid-gap

grid-column-gapgrid-row-gap的缩写语法

值:

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

示例:

.container{
  grid-template-columns: 100px 50px 100px;
  grid-template-rows: 80px auto 80px; 
  grid-gap: 10px 15px;
}

如果grid-row-gap没有定义,那么就会被设置为等同于 grid-column-gap 的值。例如下面的代码是等价的:

.container{
  /* 设置 [`grid-column-gap`](http://www.css88.com/archives/8510#prop-grid-column-row-gap) 和 [`grid-row-gap`](http://www.css88.com/archives/8510#prop-grid-column-row-gap) */  
  grid-column-gap: 10px;
  grid-column-gap: 10px; 
 
  /* 等价于 */  
  grid-gap: 10px 10px;
 
  /* 等价于 */  
  grid-gap: 10px;
}

justify-items

沿着 行轴线(row axis) 对齐 网格项(grid items) 内的内容(相反的属性是 align-items沿着列轴线对齐)。该值适用于容器内的所有网格项。

值:

.container {
    justify-items: start | end | center | stretch;
}

示例:

.container {
  justify-items: start;
}
左对齐,justify-items 设置为 start 的例子
.container{
  justify-items: end;
}
右对齐,justify-items 设置为 end 的例子
.container{
  justify-items: center;
}
居中对齐,justify-items 设置为 center 的例子
.container{
  justify-items: stretch;
}
拉伸,justify-items 设置为 stretch 的例子

这些行为也可以通过单独网格项(grid items) 的 justify-self属性设置。

align-items

沿着 列轴线(column axis) 对齐 网格项(grid items) 内的内容(相反的属性是 justify-items沿着行轴线对齐)。该值适用于容器内的所有网格项。

值:

.container {
  align-items: start | end | center | stretch;
}

示例:

.container {
  align-items: start;
}
顶部对齐,align-items 设置为 start 的例子
.container {
  align-items: end;
}
底部对齐,align-items 设置为 end 的例子
.container {
  align-items: center;
}
居中对齐,align-items 设置为 center 的例子
.container {
  align-items: stretch;
}
拉伸,align-items 设置为 stretch 的例子

这些行为也可以通过单独网格项(grid items) 的 align-self属性设置。

justify-content

有时,你的网格合计大小可能小于其 网格容器(grid container) 大小。 如果你的所有 网格项(grid items) 都使用像 px 这样的非灵活单位设置大小,在这种情况下,您可以设置网格容器内的网格的对齐方式。 此属性沿着 行轴线(row axis) 对齐网格(相反的属性是 align-content,沿着列轴线对齐网格)。

值:

.container {
  justify-content: start | end | center | stretch | space-around | space-between | space-evenly;    
}

示例:

.container {
  justify-content: start;
}
左侧对齐,justify-content 设置为 start 的例子
.container {
  justify-content: end;
}
右侧对齐,justify-content 设置为 end 的例子
.container {
  justify-content: center;
}
居中对齐,justify-content 设置为 center 的例子
.container {
  justify-content: stretch;
}
拉伸,justify-content 设置为 stretch 的例子
.container {
  justify-content: space-around;
}
justify-content 设置为 space-around 的例子
.container {
  justify-content: space-between;
}
justify-content 设置为 space-between 的例子

CSS 代码:

.container {
  justify-content: space-evenly;
}
justify-content 设置为 space-evenly 的例子

align-content

有时,你的网格合计大小可能小于其 网格容器(grid container) 大小。 如果你的所有 网格项(grid items) 都使用像 px 这样的非灵活单位设置大小,在这种情况下,您可以设置网格容器内的网格的对齐方式。 此属性沿着 列轴线(column axis) 对齐网格(相反的属性是 justify-content,沿着行轴线对齐网格)。

值:

.container {
  align-content: start |  end  | center | stretch | space-around | space-between | space-evenly;  
}

示例:

.container {
  align-content: start;  
}
顶部对齐,align-content 设置为 start 的例子
.container {
2.  align-content:  end;  
}
底部对齐,align-content 设置为 end 的例子
.container {
  align-content: center;   
}
居中对齐,align-content 设置为 center 的例子
.container {
  align-content: stretch;  
}
拉伸,align-content 设置为 stretch 的例子
.container {
  align-content: space-around;  
}
align-content 设置为 space-around 的例子
.container {
  align-content: space-between;  
}
align-content 设置为 space-between 的例子

CSS 代码:

.container {
  align-content: space-evenly;  
}
align-content 设置为 space-evenly 的例子

grid-auto-columns / grid-auto-rows

指定任何自动生成的网格轨道(grid tracks)(又名隐式网格轨道)的大小。在你明确定位的行或列(通过 grid-template-rows / grid-template-columns),超出定义的网格范围时,隐式网格轨道被创建了。

值:
– <track-size>:可以是长度值,百分比,或者等份网格容器中可用空间(使用 fr 单位)

.container {
  grid-auto-columns:  <track-size>  ...;
  grid-auto-rows:  <track-size>  ...;
}

为了说明如何创建隐式网格轨道,请考虑一下以下的代码:

.container {
  grid-template-columns:  60px  60px;
  grid-template-rows:  90px  90px
}
网格模板

生成了一个2×2的网格。

但现在想象一下,你使用 grid-columngrid-row 来定位你的网格项(grid items),像这样:

.item-a {
  grid-column:  1  /  2;
  grid-row:  2  /  3;
}

.item-b {
  grid-column:  5  /  6;
  grid-row:  2  /  3;
}
隐式网格轨道示例

我们告诉 .item-b 从第 5 条列网格线开始到第 6 条列网格线结束,但我们从来没有定义过 第5 或 第6 列网格线。
因为我们引用的网格线不存在,所以创建宽度为 0 的隐式网格轨道以填补空缺。我们可以使用 grid-auto-columnsgrid-auto-rows 来指定这些隐式轨道的大小:

.container {
  grid-auto-columns:  60px;
}
隐式网格轨道示例

grid-auto-flow

如果你有一些没有明确放置在网格上的网格项(grid items),自动放置算法 会自动放置这些网格项。该属性控制自动布局算法如何工作。

值:

.container {
  grid-auto-flow: row | column | row dense | column dense
}

请注意,dense 集可能导致你的网格项出现乱序。

示例:

考虑以下 HTML :

<section class="container">
  <div class="item-a">item-a</div>
  <div class="item-b">item-b</div>
  <div class="item-c">item-c</div>
  <div class="item-d">item-d</div>
  <div class="item-e">item-e</div>
</section>

你定义一个有 5 列和 2 行的网格,并将 grid-auto-flow设置为 row(也就是默认值):

.container {
  display: grid;
  grid-template-columns:  60px  60px  60px  60px  60px;
  grid-template-rows:  30px  30px;
  grid-auto-flow: row;
}

将网格项放在网格上时,只能为其中的两个指定位置:

CSS 代码:

.item-a {
  grid-column:  1;
  grid-row:  1  /  3;
}
.item-e {
  grid-column:  5;
  grid-row:  1  /  3;
}

因为我们把 grid-auto-flow设成了 row ,所以我们的网格看起来会是这样。注意 我们没有进行定位的网格项(item-bitem-citem-d)会这样排列在可用的行中:

自动放置算法

相反地,如果我们把 grid-auto-flow设成了 columnitem-bitem-citem-d会沿着列向下排列:

.container {
  display: grid;
  grid-template-columns:  60px  60px  60px  60px  60px;
  grid-template-rows:  30px  30px;
  grid-auto-flow: column;
}
自动放置算法

grid

在一个声明中设置所有以下属性的简写: grid-template-rows, grid-template-columns, grid-template-areas, grid-auto-rows, grid-auto-columns, 和 grid-auto-flow。它还将grid-column-gapgrid-column-gap设置为初始值,即使它们不可以通过grid属性显式地设置。

值:

.container {
  grid: none |  <grid-template-rows>  /  <grid-template-columns>  |  <grid-auto-flow>  [<grid-auto-rows>  [/  <grid-auto-columns>]];
}

例子:

以下两个代码块是等效的:

.container {
  grid:  200px  auto  /  1fr  auto  1fr;
}
.container {
  grid-template-rows:  200px  auto;
  grid-template-columns:  1fr  auto  1fr;
  grid-template-areas: none;
}

以下两个代码块也是等效的:

.container {
  grid: column 1fr  /  auto;
}
.container {
  grid-auto-flow: column;
  grid-auto-rows:  1fr;
  grid-auto-columns:  auto;
}

它也接受一个更复杂但相当方便的语法来一次设置所有内容。您可以 grid-template-areasgrid-template-rowsgrid-template-columns,并所有其他的子属性都被设置为它们的初始值。这么做可以在它们网格区域内相应地指定网格线名字和网格轨道的大小。用最简单的例子来描述:

.container {
  grid:  [row1-start]  "header header header"  1fr  [row1-end]
           [row2-start]  "footer footer footer"  25px  [row2-end]
          /  auto  50px  auto;
}

等价于:

.container {
  grid-template-areas: 
    "header header header"
    "footer footer footer";
  grid-template-rows: [row1-start] 1fr [row1-end row2-start] 25px [row2-end];
  grid-template-columns: auto 50px auto;    
}

下一篇 继续介绍网格项(Grid Items) 属性。

上一篇下一篇

猜你喜欢

热点阅读