Как создать сетку на странице. CSS-свойство flex
- 18 мая 2023
Свойство flex
— это один из двух инструментов для построения сеток и микросеток на странице. Свойство основано на концепции гибкого макета, где элементы могут растягиваться или сжиматься, чтобы использовать доступное пространство на странице наиболее эффективно.
🚀 Сегодня вам бесплатно доступен тренажёр по HTML и CSS.
Синтаксис
ul {
display: flex;
flex-direction: row;
}

Значения свойства flex
flex-grow
flex-shrink
flex-basis
flex-direction
flex-wrap
justify-content
align-items
align-self
order
Разберём значения на примерах.
Flex-grow
Значение flex-grow
определяет, как элементы будут растягиваться внутри контейнера, когда есть свободное пространство. flex-grow
может принимать целые или дробные числовые значения и по умолчанию равно 0
. Если задать flex-grow
значение больше нуля, то флекс-элемент растянется на всё оставшееся во флекс-контейнере свободное пространство.
.container {
display: flex;
}
.item-puppy {
flex-grow: 0;
}
.item-cat {
flex-grow: 1;
}

Если флекс-элементам задать одинаковые положительные значения flex-grow
, то они поровну поделят между собой свободное пространство.
.container {
display: flex;
}
.item-puppy {
flex-grow: 1;
}
.item-cat {
flex-grow: 1;
}

Flex-shrink
Значение flex-shrink
отвечает за гибкость и сжатие элементов, когда доступное пространство ограничено. Принимает числовое значение, которое указывает, какую долю свободного пространства элемент займёт при сжатии относительно других элементов в контейнере. По умолчанию равно 1
.
Все флекс-элементы по умолчанию могут сжиматься, если после определения размеров выяснилось, что места во флекс-контейнере не хватает. Если один элемент имеет flex-shrink: 2
, а другие — flex-shrink: 1
, первый элемент будет сжиматься в два раза больше остальных. В целом значение flex-shrink
используется достаточно редко. Если в микросетке большое количество элементов, то обычно сразу включают многострочный флекс-контейнер, чтобы элементы не деформировались.
.container {
display: flex;
}
.item-puppy {
flex-shrink: 2;
}
.item-cat {
flex-shrink: 1;
}
.item-corgi {
flex-shrink: 1;
}

Flex-basis
Свойство flex-basis
задает начальный размер элемента перед распределением доступного пространства. Можно указать значение в px
, mm
или в процентах вдоль главной оси. Значение по умолчанию — auto
.
Свойство flex-basis
сильнее width
и height
, оно их переопределит, если встретится с ними на одном и том же флекс-элементе.
.container {
display: flex;
}
.item-puppy {
height: 220px;
width: 220px;
flex-basis: 300px;
}
.item-cat {
height: 220px;
width: 220px;
}
.item-corgi {
height: 220px;
width: 220px;
}

Flex-direction
Свойство flex-direction
определяет направление элементов в контейнере — горизонтальное или вертикальное, что дает большую гибкость в создании различных макетов.
Можно указать одно из четырех значений:
row
— значение по умолчанию, указывает, что элементы располагаются горизонтально в контейнере. Порядок элементов определяется их последовательностью в разметке.
.container {
display: flex;
flex-direction: row;
}

row-reverse
указывает, что элементы располагаются в контейнере горизонтально, но в обратном порядке. Первый элемент становится последним, а последний элемент — первым.
css .container { display: flex; flex-direction: row-reverse; }

column
указывает, что элементы располагаются вертикально в контейнере. Каждый элемент занимает отдельную строку внутри контейнера.
css .container { display: flex; flex-direction: column; }

column-reverse
указывает, что элементы располагаются в контейнере вертикально, но в обратном порядке. Первый элемент перемещается на последнее место, а последний — на первое.
.container {
display: flex;
flex-direction: column-reverse;
}

Flex-wrap
Свойство flex-wrap
определяет, должны ли элементы переноситься на новую строку или оставаться на одной. Имеет три значения — nowrap
, wrap
, wrap-reverse
.
nowrap
— значение по умолчанию, указывает, что элементы располагаются в контейнере в одну строку или столбец. Если элементы не помещаются по ширине или высоте контейнера, они будут масштабироваться.
.container {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
}
.blue {
height: 220px;
width: 220px;
background: #4b9eb3;
}
.item-puppy {
height: 220px;
width: 220px;
background-image: url(./images/puppy.jpg);
}
.pink {
height: 220px;
width: 220px;
background: #e78830;
}
.item-cat {
height: 220px;
width: 220px;
background-image: url(./images/cat.jpg);
}

wrap
— элементы могут переноситься на следующую строку или столбец, если они не помещаются. Это позволяет создавать многострочные или многоколоночные макеты. Элементы будут размещены в новых строках или столбцах сверху вниз или слева направо, в зависимости от ориентации основной оси.
.container {
display: flex;
flex-direction: row;
flex-wrap: wrap;
}
.blue {
height: 220px;
width: 220px;
background: #4b9eb3;
}
.item-puppy {
height: 220px;
width: 220px;
background-image: url(./images/puppy.jpg);
}
.pink {
height: 220px;
width: 220px;
background: #e78830;
}
.item-cat {
height: 220px;
width: 220px;
background-image: url(./images/cat.jpg);
}
.green {
height: 220px;
width: 220px;
background: #4bb381;
}
.item-corgi {
height: 220px;
width: 220px;
background-image: url(./images/corgi.jpg);
}

wrap-reverse
— значение работает аналогично wrap
, но элементы будут переноситься на следующую строку или столбец в обратном порядке. Например, если в flex-direction
указано row
, элементы будут переноситься на новую строку справа налево.
.container {
display: flex;
flex-direction: row;
flex-wrap: wrap-reverse;
}
.blue {
height: 220px;
width: 220px;
background: #4b9eb3;
}
.item-puppy {
height: 220px;
width: 220px;
background-image: url(./images/puppy.jpg);
}
.pink {
height: 220px;
width: 220px;
background: #e78830;
}
.item-cat {
height: 220px;
width: 220px;
background-image: url(./images/cat.jpg);
}
.green {
height: 220px;
width: 220px;
background: #4bb381;
}
.item-corgi {
height: 220px;
width: 220px;
background-image: url(./images/corgi.jpg);
}

Justify-content
Свойство justify-content
распределяет элементы вдоль главной оси контейнера.
У свойства есть ряд значений:
flex-start
— значение по умолчанию, оно указывает, что флекс-элементы выровнены по началу главной оси контейнера. Если основная ось направлена горизонтально, то элементы будут выравниваться слева, а если ось направлена вертикально, то элементы будут выравниваться сверху.
.container {
display: flex;
flex-direction: row;
justify-content: flex-start;
}

flex-end
указывает, что флекс-элементы выровнены по концу главной оси контейнера. Если основная ось направлена горизонтально, то элементы будут выравниваться справа, а если ось направлена вертикально — снизу.
.container {
display: flex;
flex-direction: row;
justify-content: flex-end;
}

center
указывает, что флекс-элементы выровнены по центру главной оси контейнера. Элементы будут выравниваться горизонтально или вертикально в центре контейнера.
.container {
display: flex;
flex-direction: row;
justify-content: center;
}

space-between
указывает, что флекс-элементы равномерно распределены вдоль главной оси контейнера. Первый элемент будет выровнен в начале оси, а последний элемент — в конце. Промежутки между элементами будут распределены равномерно.
.container {
display: flex;
flex-direction: row;
justify-content: space-between;
}

space-around
означает, что флекс-элементы равномерно распределены вдоль главной оси контейнера с равными промежутками как до, так и после каждого элемента.
.container {
display: flex;
flex-direction: row;
justify-content: space-around;
}

space-evenly
указывает, что элементы равномерно распределены вдоль главной оси контейнера, и промежутки между ними и на краях контейнера равны.
.container {
display: flex;
flex-direction: row;
justify-content: space-evenly;
}

Align-items
Свойство align-items
определяет выравнивание элементов вдоль поперечной оси контейнера.

align-items
имеет несколько значений:
flex-start
— флекс-элементы выровнены по началу поперечной оси контейнера. Если поперечная ось направлена горизонтально, то элементы будут выравниваться вверху, а если ось направлена вертикально, то элементы будут выравниваться слева.
.container {
display: flex;
flex-direction: row;
align-items: flex-start;
}

flex-end
— флекс-элементы выровнены по концу поперечной оси контейнера.
.container {
display: flex;
flex-direction: column;
align-items: flex-end;
}

center
— флекс-элементы выровнены по центру поперечной оси контейнера. Элементы будут выравниваться горизонтально или вертикально в центре контейнера.
.container {
display: flex;
flex-direction: column;
align-items: center;
}

baseline
— флекс-элементы выровнены по базовой линии, которая обычно используется для выравнивания текста.
stretch
— значение по умолчанию. Указывает, что элементы должны растягиваться по высоте или ширине контейнера, чтобы занять всю доступную площадь вдоль поперечной оси. Это значение делает флекс-элементы одинаковой высоты или ширины, в зависимости от ориентации поперечной оси.
Align-self
Свойство align-self
определяет выравнивание отдельного элемента вдоль поперечной оси контейнера. Это свойство задаётся флекс-элементу, а не флекс-контейнеру, и имеет такие же значения, как свойство align-items
.
.container {
display: flex;
flex-direction: column;
align-items: baseline;
}
.item-puppy {
height: 220px;
width: 220px;
background-image: url(./images/puppy.jpg);
align-self: center;
}

Order
Значение order
определяет порядок отображения элементов в контейнере, задаётся нужному флекс-элементу. Числовое значение определяет порядковый номер элемента, и чем меньше число, тем ближе элемент будет располагаться к началу контейнера.
.container {
display: flex;
}
.item:first-child {
order: 2;
}
.item:last-child {
order: 1;
}

Нюансы использования
- Свойство
flex
работает только для элементов, у которых значение свойстваdisplay
установлено наflex
. - Если элементы не помещаются в одну строку или колонку из-за ограничений ширины или высоты контейнера, используется свойство
flex-wrap
со значениемwrap
, чтобы элементы переносились на новую строку или колонку. - Расположение элементов в HTML-файле не имеет решающего значения. Порядок элементов можно поменять в CSS.
- Если нужно задать порядок отображения элементов, можно использовать свойство
order
, где меньшее значение будет помещать элемент ближе к началу контейнера. - Множество языков в мире используют написание справа налево
rtl
(right-to-left), в отличие от привычногоltr
(left-to-right). Флекс адаптирован для этого. В нем есть понятие начала и конца, поэтому в браузерах с локальюrtl
все элементы будут автоматически расположены в реверсном порядке.
📌 Актуальная информация о поддержке браузерами свойства flex
на caniuse.
Материалы по теме
«Доктайп» — журнал о фронтенде. Читайте, слушайте и учитесь с нами.
Читать дальше

Как анимировать CSS Grids без JavaScript
Grid Layout — одна из самых зрелых технологий в CSS. Он давно решает задачи макета гораздо лучше, чем float
, flex
и position
. Но долгое время у него была одна неочевидная граница: анимация размеров сетки.
Да, grid-template-columns
и grid-template-rows
существовали с самого начала появления гридов. Да, они были мощными. Но плавно менять их было нельзя — браузеры просто прыгали между состояниями. Анимация сетки оставалась мечтой.
Ситуация изменилась c 27 апреля 2025 года. Анимация grid-template-columns
и grid-template-rows
вошла в baseline — это означает, что теперь она официально поддерживается всеми современными браузерами. Без флагов. Без хака с display: contents
. Просто работает.
- 1 июня 2025

Все единицы измерения в CSS от лучших к худшим
CSS использует разные единицы измерения для задания размеров, отступов, шрифтов и других свойств. Разделяют абсолютные и относительные единицы. Понимание различий между ними — фундаментальная основа адаптивной, масштабируемой и удобной в поддержке вёрстки.
Абсолютные:
px
— пикселиcm
— сантиметрыmm
— миллиметрыin
— дюймыpt
— типографские пунктыpc
— пика
Относительные:
z%
— процент от родителяem
— от размера шрифта родителяrem
— от размера шрифта корняvw
— 1% от ширины вьюпортаvh
— 1% от высоты вьюпортаvmin
/vmax
— минимальное/максимальное из vw и vhfr
— доля пространства в грид-сеткеch
— ширина символа «0»ex
— высота строчной буквы «x»
Примеры ниже снабжены пояснениями из практики, с фокусом на применение в реальных проектах.
- 30 мая 2025

Как размыть фон под элементом с помощью backrop-filter
В сентябре 2024 в Baseline в статусе Widely-available вошло CSS-свойство backdrop-filter
. Оно делает красивое: позволяет применить фильтры (размытие, контраст, яркость, и прочее) к фону за элементом. Не к самому элементу, а именно к тому, что за ним — это важно.
То есть если у вас есть модальное с полупрозрачным фоном, вы можете сделать так, чтобы то, что под ней, красиво размывалось, как в macOS или на айфоне. Это и есть главное применение backdrop-filter
.
Пример минимального кода:
<div class="glass-panel">Контент</div>
.glass-panel {
backdrop-filter: blur(10px);
background-color: rgba(255, 255, 255, 0.3);
}
Чтобы это работало, у элемента должен быть фон с прозрачностью (например, rgba или hsla), иначе фильтр не виден. И да, backdrop-filter
визуально различим только если элемент реально перекрывает что-то.
- 5 мая 2025

Справочник по новым математическим функциям CSS
За последние годы в CSS добавилось много математических функций, для которых не нужен JavaScript. Их можно использовать в анимациях, в графиках для визуализации данных или просто для создания красивых пользовательских интерфейсов.
Эта статья — справочник, который вы можете добавить в закладки и обращаться по мере необходимости. А подробно ознакомиться с работой математических функций можно в интерактивной демонстрации в HTML Academy.
Статья дополняется.
- 28 апреля 2025

CSS Scroll-Driven Animations: что это, зачем нужно и как начать пользоваться
Раньше, чтобы анимировать что-то при прокрутке, приходилось писать JavaScript. Слушать события scroll
, вычислять позиции элементов, руками задавать стили. Это было сложно и работало неэффективно. Но в 2025 в CSS появилась нормальная нативная поддержка скролл-анимаций.
Частичная поддержка есть в Chrome 115+, Edge 115+ и Opera 117+, с флагами — в Firefox 110+. Ждём ещё Safari.
Внимание! Все примеры в этой статье работают только в Chrome 116+.
- 27 апреля 2025

Анимация по любой траектории с offset-path
У вас же было такое, что ждёте курьера или доставку, а их всё нет и нет? Заходите сайт, обновляете статус, а там «В пути» и больше никакой информации. У нас вот было много раз.
В хороших случаях курьера рисуют прямо на карте, и показывают, где он едет, где проехал, и прямо анимацией можно всё рассмотреть.
- 18 апреля 2025

Автоматическая тёмная тема: новая CSS-функция light-dark()
CSS-функция light-dark()
облегчает жизнь при поддержке светлой и тёмной темы. Раньше, чтобы задать разные стили для разных тем, приходилось писать медиа-выражения вроде @media (prefers-color-scheme: dark)
и дублировать одни и те же куски стилей с поправками на цвет. Это работало, но выглядело избыточно и громоздко, особенно когда надо было поменять всего один цвет. Для системности создавались CSS-переменные — например, --text-color
, значение которой менялось внутри медиавыражения. Всё это работало, но напоминало церемонию ради церемонии.
С light-dark()
всё стало проще. Это функция, которая на лету подставляет значение в зависимости от активной темы. Если у пользователя включена светлая тема, функция вернёт первое значение. Если тёмная — второе. Пример: color: light-dark(black, white)
— в светлой теме будет чёрный текст, в тёмной — белый. Всё. Никаких переменных, никаких @media
. Просто одно свойство и два значения — читаемо, логично, компактно.
- 23 апреля 2024

Псевдокласс :link
Псевдокласс :link
в CSS предназначен для стилизации ссылок, которые ещё не были посещены пользователем. Этот псевдокласс позволяет разработчикам задавать внешний вид для непосещенных ссылок отдельно от тех, по которым пользователь уже переходил, что помогает лучше ориентироваться на странице и повышает удобство использования сайта.
Пример использования псевдокласса :link
для стилизации непосещенных ссылок:
a:link {
color: #007bff;
text-decoration: none;
}
В данном примере для всех непосещенных ссылок устанавливается синий цвет (#007bff
) и убирается подчеркивание. Это делает внешний вид ссылок более аккуратным и одновременно информативным, поскольку пользователь может легко отличить их от уже посещенных (:visited
) ссылок.
При работе с :link
, важно помнить, что этот псевдокласс должен использоваться в сочетании с псевдоклассом :visited
для полной стилизации состояний ссылок. Также рекомендуется определять стили для псевдоклассов :hover
и :active
, чтобы обеспечить интерактивный и отзывчивый интерфейс.
Пример полного набора стилей для ссылок:
a:link {
color: #007bff;
text-decoration: none;
}
a:visited {
color: #666;
}
a:hover {
color: #0056b3;
text-decoration: underline;
}
a:active {
color: #ff0000;
}
В этом примере задаются различные стили для всех возможных состояний ссылок: :link
для непосещённых, :visited
для посещённых, :hover
при наведении курсора и :active
в момент нажатия на ссылку. Такой подход позволяет создать более динамичный и интуитивно понятный интерфейс веб-страницы.
- 4 апреля 2024

Селектор потомков (пробел)
Селектор потомков в CSS используется для выбора элементов, которые являются потомками другого элемента в структуре документа. Этот селектор обозначается простым пробелом между двумя селекторами и позволяет применить стили к элементам, находящимся внутри других элементов, независимо от глубины их вложенности.
Пример использования селектора потомков:
article p {
color: #333;
line-height: 1.6;
}
В данном примере все абзацы (<p>
), которые находятся внутри элемента <article>
, будут окрашены в темно-серый цвет и получат межстрочный интервал в полтора размера шрифта. Селектор потомков позволяет легко управлять стилем конкретных элементов, сохраняя при этом общую структуру и читаемость кода.
Селектор потомков особенно полезен в следующих случаях:
- Структурирование контента: Помогает стилизовать элементы внутри определенных секций или компонентов, не затрагивая похожие элементы в других частях страницы.
- Тематическое оформление: Используется для применения уникальных стилей к элементам, расположенным внутри определенных контейнеров, например, для статей, сайдбаров или футеров.
- Изоляция стилей: Обеспечивает локальное применение стилей, предотвращая их случайное распространение на другие элементы документа.
Применение селектора потомков упрощает создание модульной и легко поддерживаемой структуры стилей, позволяя разработчикам более точно и гибко управлять внешним видом веб-страницы.
Однако, важно соблюдать баланс и избегать слишком глубокой вложенности селекторов, так как это может усложнить поддержку и оптимизацию кода. Рекомендуется использовать селектор потомков с умом, ориентируясь на поддержание чистоты и простоты структуры CSS.
- 4 апреля 2024

Псевдокласс :focus
Псевдокласс :focus
в CSS используется для стилизации элементов, которые получили фокус. Это может быть, например, текстовое поле в форме, к которому пользователь переместил курсор для ввода, или ссылка, выбранная через клавиатурный ввод. Псевдокласс :focus
позволяет создать более интерактивный и доступный пользовательский интерфейс, подсвечивая активные или выбранные элементы.
Пример использования :focus
:
input:focus {
border: 2px solid blue;
background-color: lightblue;
}
В этом примере для всех текстовых полей (input
) при получении фокуса будет изменяться цвет границы на синий и фоновый цвет на светло-синий. Это обеспечивает наглядную обратную связь пользователю о том, какой элемент формы активен в данный момент, улучшая общую пользовательскую доступность и удобство использования интерфейса.
Псевдокласс :focus
особенно важен для:
- Улучшения доступности: Он помогает пользователям с ограниченными возможностями или теми, кто использует клавиатурный ввод вместо мыши, понимать, какой элемент управления в данный момент активен.
- Повышения интерактивности: Визуальное отличие активных элементов делает интерфейс более дружелюбным и понятным для пользователя.
- Создания стилистических акцентов: Позволяет добавлять уникальные стилистические особенности для интерактивных элементов интерфейса, подчеркивая их функциональность.
Применение :focus
в сочетании с другими псевдоклассами, такими как :hover
и :active
, позволяет создать комплексное визуальное представление различных состояний элементов управления, делая интерфейс более интуитивно понятным и приятным в использовании.
Однако, важно помнить, что стилизация элементов при помощи :focus
должна быть достаточно заметной, чтобы пользователь мог легко идентифицировать фокусируемый элемент, но при этом не должна быть слишком навязчивой, чтобы не отвлекать от общего восприятия интерфейса.
- 4 апреля 2024