Вход

CSS Grid. Инструкция по применению

CSS Grid. Инструкция по применению

В данной статье мы разберёмся в каких случаях необходимы css grid, а в каких можно обойтись обычными flexbox.

Есть различные варианты сеток и некоторые из них легко могут быть реализуемы с помощью flexbox, но встречаются и другие где требуется поиск других решений (css grid) или компоновка блоков для технологии flexbox что существенно усложняет html код.

Сетка на Flexbox:


Сетка на css grid:

Для использования css grid необходимо прописать правило для обёртки:

Задание основной сетки

1
2
3
.wrap{
display:grid;
}

Задаём сетку:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
.wrap{
display:grid;
 
// количество колонок (можно использовать auto)
grid-template-columns: 150px 150px;
// задание двух одинаковых колонок
grid-template-columns: repeat(2, 150px);
// 8 колонок
grid-template-columns: 100px repeat(6, 1fr) 150px;
 
 
// количество строк (можно использовать auto)
grid-template-rows: 100px 200px 150px;
 
}

Колонка во всё свободное место:

1
2
// 1fr = flex-grow:1;
grid-template-columns: 300px 1fr;

Растянуть строку по высоте:

1
2
3
4
5
6
.wrap{
min-height:100vh;
display:grid;
// 1fr = flex-grow:1;
grid-template-row: 100px 1fr 150px;
}

Задание размеров ячеек

1
2
3
4
5
6
7
8
9
10
.block1{
grid-column: столбец начала блока / столбец конца блока
// блок будет занимать три столбца
grid-column: 1 / 3; 
 
// или
grid-column: столбец начала блока / span сколько столбцов занимает
// блок будет занимать три столбца
grid-column: 1 / span 3; 
}

Задание строки вывода для ячейки

1
2
3
4
5
6
7
8
.block4{
grid-row: номер строки
grid-row:2;
 
или
// ячейка начинается со второй строки и занимает 2 строки
grid-row:2 / span 2;
}

Размеры ячеек через именование

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
header{
// задаём имена для блоков через grid-area
grid-area: header;
}
footer{
grid-area: footer;
}
.content{
grid-area: content;
}
aside{
grid-area: aside;
}
// объединяем ячейки
.wrap{
display:grid;
// количество колонок
grid-template-columns: 150px 150px;
// количество строк
grid-template-rows: 100px 200px 150px;
 
// структура в соответствии с  правилами grid-template-columns и grid-template-rows
grid-template-areas: "header header" 
                     "content aside" 
                     "footer footer";   
}

Отступы в Grid css

1
2
3
4
5
6
7
8
9
10
.wrap{
// отступы между колонками
grid-column-gap: 10px;
 
// отступы между строками
grid-row-gap: 20px;
// составное правило для отступов
//grid-gap: [отступы строк] [отступы столбцов];
grid-gap: 20px 10px;
}

Выравнивание ячеек

Вдоль оси строки:

start — по левой стороне

end — по правой стороне

center — по центру

stretch — по всей ширине

1
2
3
.wrap{
justify-items:start;
}

Вдоль оси столбца:

start — по левой стороне

end — по правой стороне

center — по центру

stretch — по всей ширине

1
2
3
.wrap{
align-items:start 
}

Выравнивание сетки:

start — по левой стороне

end — по правой стороне

center — по центру

stretch — по всей ширине

space-around — одинаковые отступы между элементами и по краям

space-between — без отступов по краям

space-evenly — полноразмерные отступы по краям

1
2
3
.wrap{
justify-content:start 
}

Выравнивание ячейки по оси строки:

start — по левой стороне

end — по правой стороне

center — по центру

stretch — по всей ширине

1
2
3
.wrap{
justify-self:start;
}

Выравнивание ячейки по столбцу:

start — по левой стороне

end — по правой стороне

center — по центру

stretch — по всей ширине

1
2
3
.wrap{
align-self:start;
}

22 февраля 2019 /

4030 Views /

0 Comment
Ilya Web developer
Author

«Всегда пишите код так, будто сопровождать его будет склонный к насилию психопат, который знает, где вы живете.»Martin Golding