CSS Grid Layout — это способ разметки, который позволяет создавать на странице простые и сложные двумерные сетки. Вы можете добавить любое количество столбцов или строк и указать, сколько ячеек должен занимать каждый элемент.

🚀 Сегодня вам бесплатно доступен тренажёр по HTML и CSS.

Например, с помощью гридов легко создать такой раздел:

Это трёхколоночная сетка с тремя строками. Блок с перфораторами занимает две колонки и два ряда, между элементами заданы равные отступы

Если пока не знаете, в чём разница, прочитайте, когда использовать флексы, а когда гриды.

Как создать сетку на гридах

Чтобы добавить сетку, нужно в стилях родительского элемента написать display: grid. Далее указывается количество столбцов и строк в сетке, задаются их размеры.

Описать количество и размеры столбцов — grid-template-columns.

Описать количество и размеры строк — grid-template-rows.

Например, так создаётся сетка из двух столбцов шириной 200px и двух строк высотой 150px:

<ul class="cats">
  <li>Барсик</li>
  <li>Снежок</li>
  <li>Бублик</li>
  <li>Васька</li>
</ul>
.cats {
  display: grid;
  grid-template-columns: 200px 200px;
  grid-template-rows: 150px 150px;
}

Как задать размеры столбцов и строк

В процентах. Ширина колонки и высота ряда считаются относительно родительского контейнера. Например, grid-template-columns: 50% 50% создаст две одинаковые колонки шириной в половину родительского элемента.

В пикселях. Устанавливает точную ширину столбца или высоту строки — мы так делали в примере с котами: grid-template-columns: 200px 200px.

С помощью ключевого слова auto. Размеры вычисляются автоматически, в зависимости от свободного пространства.

C помощью ключевого слова fr (fraction). Всё пространство в сетке делится на равные доли fr. Например, колонка grid-template-columns: 1fr растянется на всю область родительского контейнера. А если написать grid-template-columns: 1fr 2fr, вы получите две колонки, при этом вторая будет в два раза шире.

Использовать разные значения. Можно смешивать значения, чтобы добиться большей точности или гибкости:

div {
  display: grid;
  grid-template-columns: 200px 1fr 1fr 25%;
}

В этом примере мы создаём четыре колонки. У первой фиксированная ширина, последняя занимает 25% пространства, а вторая и третья делят оставшееся пространство на две равные доли.

Как разместить элементы в гриде

По умолчанию все элементы располагаются в гриде слева направо сверху вниз и занимают одну ячейку сетки. Нумерация считается по линиям, как на картинке:

Сетка из трёх столбцов и двух рядов

Чтобы расположить элемент в сетке, нужно задать ему координаты. Например, первый кот начинается на линии 1 столбца и линии 1 ряда, а заканчивается на линии 2 столбца и линии 2 ряда. Кот в очках начинается на 3 линии столбца и 1 линии строки, а заканчивается на 4 линии столбца и 2 линии строки.

Также можно использовать обратную нумерацию. Это полезно, например, когда нужно работать с элементами в крайнем правом столбце или нижнем ряду.

Здесь кот в очках находится между линиями столбцов -1 и -2:

Сетка из трёх столбцов и двух строк, но с обратной нумерацией

Стили для расположения элементов в сетке: grid-column и grid-row

grid-column-start и grid-column-end указывают, в каком столбце начинается элемент и в каком заканчивается. Например:

<ul class="cats">
  <li class="keks">Кекс</li>
  <li>Барсик</li>
  <li>Снежок</li>
  <li>Бублик</li>
  <li>Васька</li>
</ul>
.keks {
  grid-column-start: 1;
  grid-column-end: 3;
  /*Элемент растянется на две колонки с первой по третью линию*/
}

grid-row-srart и grid-row-end указывают, какие строки занимает элемент. Здесь всё, как со столбцами:

.keks {
  grid-row-srart: 1;
  grid-row-end: 3;
  /*Элемент растянется на две строки, с первой по третью линию*/
}

Для этих свойств есть сокращённые записи: grid-column и grid-row. В них можно сразу прописать, на какой линии начинается и заканчивается элемент — это делается через черту, вот так: grid-row: 1/3.

<ul class="cats">
  <li class="keks">Кекс</li>
  <li>Барсик</li>
  <li>Снежок</li>
  <li>Бублик</li>
  <li>Васька</li>
</ul>
.keks {
  /*Элемент займёт две строки.*/
  grid-row: 1/3
}
Фотография Кекса растянулась на две строки

Свойство grid-area и repeat

Свойство grid-area

Писать каждый раз начальные и конечные координаты для столбцов и рядов — долго и не всегда удобно. Но можно сократить запись с помощью свойства grid-area, оно объединяет и заменяет grid-column и grid-row.

Свойство grid-area принимает четыре значения, которые разделяются косой чертой: grid-row-startgrid-column-startgrid-row-end и grid-column-end:

li {
  grid-area: 2 / 1 / 4 / 3;
}

Эта же запись в полном варианте:

li {
  grid-column: 1/3;
  grid-row: 2/4;
}

Ключевое слово repeat

Второй способ сократить код — использовать ключевое слово repeat. Оно помогает, когда в grid-template-columns или grid-template-columns нужно создать множество одинаковых колонок или рядов:

li {
  grid-template-columns: 200px 200px 200px 200px 200px;
}

С ключевым словом repeat код выглядит так:

li {
  grid-template-columns: repeat(5, 200px);
}

В скобках после repeat сначала указывается количество строк или столбцов, а затем через запятую пишется их размер.

Границы и отступы

Границы между элементами задаются с помощью свойства gap. Например, gap: 10px добавит отступы между элементами по бокам и сбоку:

Чтобы задать только боковые отступы, используйте grid-column-gap, а для отступов между рядами — grid-row-gap.

Как изменить порядок элементов

Есть два способа.

Первый — указать расположение элемента с помощью grid-column, grid-row или grid-area. К примеру, у нас есть такой список:

<div class="grid">
  <div class="keks">Кот Кекс</div>
  <div>Кот Барсик</div>
  <div>Кошка Василиса</div>
  <div>Кот Борис</div>
</div>
.grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  ...
}

На странице он выглядит так:

Поменяем порядок. Сделаем так, чтобы Кекс стал третьим и перешёл на вторую строку. Разметку не меняем, только стили:

.keks {
  grid-row: 2/3;
}

Получаем:

С помощью стилей вы можете указать координаты для каждого элемента и даже наложить один элемент на другой, если это нужно.

Второй способ — использовать свойство order. По умолчанию элементы грида имеют order, равный 0, но это значение можно менять. Например, вот что произойдёт, если мы добавим «Кексу» order: 1:

.keks {
  order: 1;
}

Элемент переместится в конец:

Где отточить навык работы с гридами

«Старт в программировании» — курс для новичков. Он научит вас создавать страницы, в том числе строить сетки на флексах и гридах. Курс основан на тренажёрах и мастер-классах.

Grid Garden — интерактивная игра, которая поможет понять основы CSS Grid Layout. Вам предстоит поливать грядки с морковью и уничтожать сорняки с помощью гридов.

Раздел о CSS Grid Layout — страница на официальной документации MDN. Поможет расширить знания о гридах и не только.

Grid by Example — на этом сайте вы найдёте множество примеров использования CSS Grid. Все статьи здесь на английском языке, но их можно перевести через переводчик, встроенный в браузер.

Материалы по теме