Перейти к содержанию

grid-template

Свойство grid-template — сокращение для grid-template-rows, grid-template-columns, и grid-template-areas.

Демо

Grid Layout

Синтаксис

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/* Keyword value */
grid-template: none;

/* grid-template-rows / grid-template-columns values */
grid-template: 100px 1fr / 50px 1fr;
grid-template: auto 1fr / auto 1fr auto;
grid-template: [linename] 100px / [columnname1] 30% [columnname2] 70%;
grid-template: fit-content(100px) / fit-content(40%);

/* grid-template-areas grid-template-rows / grid-template-column values */
grid-template:
    'a a a'
    'b b b';
grid-template:
    'a a a' 20%
    'b b b' auto;
grid-template:
    [header-top] 'a a a' [header-bottom]
    [main-top] 'b b b' 1fr [main-bottom]
    / auto 1fr auto;

/* Global values */
grid-template: inherit;
grid-template: initial;
grid-template: unset;

Значения

none

устанавливает все три свойства в их начальное значение;

subgrid

устанавливает grid-template-rows и grid-template-columns в subgrid, и grid-template-areas в его начальное значение;

<grid-template-rows> / <grid-template-columns>

устанавливает grid-template-columns и grid-template-rows в определённое значение, соответственно, и устанавливает grid-template-areas в none;

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

Он также принимает более сложный, но довольно удобный синтаксис, для указания всех трёх свойств. Вот пример:

1
2
3
4
5
6
.container {
    grid-template:
        [row1-start] 25px 'header header header' [row1-end]
        [row2-start] 'footer footer footer' 25px [row2-end]
        / auto 50px auto;
}

Что эквивалентно следующему:

1
2
3
4
5
6
7
.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-columns, grid-auto-rows, и grid-auto-flow), а в большинстве случаев, вероятно, вы бы захотели это сделать, рекомендуется использовать свойство grid, вместо grid-template.

Спецификации

Поддержка браузерами

Can I Use css-grid? Data on support for the css-grid feature across the major browsers from caniuse.com.

Описание и примеры

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#page {
  display: grid;
  width: 100%;
  height: 200px;
  grid-template:
    [header-left] 'head head' 30px [header-right]
    [main-left] 'nav  main' 1fr [main-right]
    [footer-left] 'nav  foot' 30px [footer-right]
    / 120px 1fr;
}

header {
  background-color: lime;
  grid-area: head;
}

nav {
  background-color: lightblue;
  grid-area: nav;
}

main {
  background-color: yellow;
  grid-area: main;
}

footer {
  background-color: red;
  grid-column: foot;
}
1
2
3
4
5
6
<section id="page">
  <header>Header</header>
  <nav>Navigation</nav>
  <main>Main area</main>
  <footer>Footer</footer>
</section>

Пример использования свойства grid-template

См. также

Комментарии