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

px — пиксели
Тип: абсолютная
Поддержка: везде
Применение: повсеместно
body {
font-size: 16px;
margin: 20px;
}
Когда использовать: Пиксели подходят для точных размеров, таких как иконки, кнопки и UI-элементы. Часто применяются как базовая единица, особенно на макетах.
Когда избегать: Не стоит использовать для шрифтов — это мешает доступности. Также нежелательны в адаптивной вёрстке: не масштабируются под размер экрана.
Совет: Используйте умеренно, для точных деталей.
% — проценты
Тип: относительная
Применение: ширина, отступы, шрифты (редко)
.container {
width: 80%;
}
Когда использовать: Идеальны для ширины элементов, особенно вложенных блоков, которым нужно наследовать размеры от родителя.
Когда избегать: В высоте могут вести себя непредсказуемо, если родитель не имеет заданной высоты.
Совет: Отлично работает для ширины, особенно в гибких макетах.
rem — относительная к корневому шрифту
Тип: относительная
Применение: шрифты, отступы, размеры, ширина контейнеров
html {
font-size: 16px;
}
h1 {
font-size: 2rem; /* 32px */
}
Когда использовать: Хорош для масштабируемых интерфейсов: одно изменение font-size в масштабирует всё остальное.
Когда избегать: Почти не бывает причин избегать — универсален и удобен.
Совет: Рекомендуется как основная единица для всех размеров.
em — относительная к родительскому шрифту
Тип: относительная
Применение: шрифты, отступы, вложенные компоненты
button {
font-size: 1em;
padding: 0.5em 1em;
}
Когда использовать: Удобен внутри компонентов, где размеры зависят от родителя. Хорош для внутренних отступов.
Когда избегать: В каскаде может дать неожиданный результат, если вложенность сложная.
Совет: Используйте для компонентов, особенно при оформлении кнопок и карточек.
vw / vh — проценты от вьюпорта
Тип: относительная
1vw
= 1% от ширины окна1vh
= 1% от высоты окна
.hero {
height: 100vh;
font-size: 5vw;
}
Когда использовать: Отличны для полноэкранных секций, динамичных заголовков и блоков, завязанных на размер экрана.
Когда избегать: На мобильных могут вести себя нестабильно — адресная строка влияет на размер окна.
Совет: Используйте с осторожностью, особенно vh
на iOS — лучше lvh
или JS-хаки.
fr — единица фракции в grid
Тип: относительная
Применение: grid-template-columns
, grid-template-rows
.grid {
display: grid;
grid-template-columns: 1fr 2fr;
}
Когда использовать: Лучший выбор для гибких макетов на Grid. Позволяет легко делить пространство.
Когда избегать: Почти нет причин избегать — универсальна в пределах грида.
Совет: По умолчанию выбирайте fr
в грид-сетках.
ch — ширина «0» символа
Тип: относительная
Применение: ширина полей ввода, консольных блоков
input {
width: 30ch;
}
Когда использовать: Идеален для полей форм, особенно когда нужна ширина по количеству символов.
Когда избегать: Не годится, если используется не моноширинный шрифт.
Совет: Удобен в <input>
и <textarea>
.
ex — высота строчной буквы x
Тип: относительная
Редкость: крайне редко используется
p {
line-height: 2ex;
}
Когда использовать: Почти никогда — очень специфична, зависит от шрифта.
Когда избегать: Лучше избегать всегда, если нет веских причин.
cm, mm, in — сантиметры, миллиметры, дюймы
Тип: абсолютные
Применение: печатные стили (@media print
)
@media print {
body {
width: 21cm;
}
}
Когда использовать: Только в печатной вёрстке.
Когда избегать: Не для экранной вёрстки — нет смысла.
pt / pc — типографские пункты
Применение: аналогично cm/mm — только в печати.
ic — ширина идеографического символа
Тип: относительная
Происходит от: ideographic character
Применение: вёрстка на CJK-языках (китайский, японский, корейский)
input {
width: 10ic;
}
Когда использовать:ic
подходит для интерфейсов на языках с идеографическим письмом. Например, чтобы задать ширину поля ввода, в которое должно помещаться ровно 10 иероглифов, используйте width: 10ic
. Эта единица учитывает ширину текущего шрифта и делает вёрстку более естественной для азиатских пользователей.
Когда избегать:
В интерфейсах на кириллице или латинице ic
не даёт ожидаемых результатов. Поведение может быть непредсказуемым, особенно если используется неидеографический шрифт или смешанные символы.
Совет: Отлично работает в сочетании с CJK-шрифтами и интерфейсами на восточноазиатских языках. Для остальных случаев предпочтительнее ch
.
Итоговая таблица применения
Единица | Тип | Применение | Стоит использовать? |
---|---|---|---|
px | абсолютная | UI, точные отступы | Да, но с осторожностью |
% | относительная | ширина, вложенность | Да |
rem | относительная | масштабируемые размеры, особенно шрифт | Да |
em | относительная | компоненты, отступы | Да, с учётом контекста |
vw/vh | относительная | hero-блоки, fullscreen | Да, но проверять в мобилках |
fr | относительная | Grid layout | Да, без ограничений |
ch | относительная | формы, поля ввода | Да |
ex | относительная | спецкейсы | Нет |
cm/mm/in | абсолютная | печать | Да, только для print |
pt/pc | абсолютная | печать | Да, только для print |
Если вы новичок — начните с rem
, %
, px
и fr
. Постепенно подключайте em
и vw/vh
, когда поймёте поведение и каскад.
Хорошая практика:
- Шрифты —
rem
- Внутренние отступы —
em
- Сетки —
fr
- Размеры контейнеров —
%
илиvw
- Точные размеры —
px
Грамотное сочетание единиц делает вашу вёрстку гибкой, адаптивной и масштабируемой.
«Доктайп» — журнал о фронтенде. Читайте, слушайте и учитесь с нами.
Читать дальше

10 свойств в CSS о которых вы, вероятно, не знали
Если вы только начинаете разбираться в CSS, скорее всего, вам кажется, что мир стилей ограничивается свойствами вроде margin
, color
, font-size
и может быть, flex
. Но CSS — это не просто про то, чтобы задать цвет кнопке и отступ между блоками. За простыми примерами скрывается целый мир возможностей, о которых многие не догадываются. В этой статье рассказываем о десяти свойствах, которые встречаются редко, но способны заметно упростить вам жизнь или добавить в проект изюминку.
- 22 июня 2025

Округление в CSS с функцией round()
Функция round()
появилась в CSS как часть стандарта Values and Units Level 4. Она предназначена для округления числовых значений до нужной кратности. Это полезный инструмент, который позволяет контролировать размеры и позиции без лишних ухищрений с calc()
или JavaScript.
- 22 июня 2025

focus-visible
Когда мы создаём сайты, мы хотим, чтобы ими было удобно пользоваться всем людям — и тем, кто управляет страницей с помощью мыши, и тем, кто использует клавиатуру. Например, человек с ограниченными возможностями зрения может перемещаться по элементам с помощью клавиши Tab
.
Браузеры по умолчанию показывают рамку (outline) вокруг элемента, когда он получает фокус — например, при клике мышкой или при перемещении с помощью клавиатуры. Эта рамка помогает понять, какой элемент активный.
Но бывает так, что рамка появляется даже тогда, когда она не нужна. Например, Вы кликнули мышкой по кнопке, и вокруг неё появилась рамка — выглядит не очень красиво, а пользы от неё нет, потому что курсор мыши уже показывает, куда мы кликнули.
Тут и помогает :focus-visible
. Этот псевдокласс позволяет показывать рамку только в тех случаях, когда это действительно полезно — обычно при навигации с клавиатуры.
- 21 июня 2025

CSS font-palette: управление цветами шрифтов
Свойство font-palette
позволяет выбрать одну из цветовых палитр, встроенных в цветной шрифт, или создать свою. При использовании — оно задаёт преобладающую окраску глифов, и свойство color
уже не влияет.
В свою очередь, цветной шрифт — это шрифт, в котором глифы содержат встроенную информацию о цвете. В отличие от обычных векторных шрифтов (TrueType, OpenType), где цвет задаётся снаружи с помощью CSS-свойства color, в цветном шрифте сами глифы уже закодированы с цветными деталями — например, несколько заливок, градиенты, обводки, изображения.
Альтернативные цветовые палитры шрифта Nabla (Typearture, Google Fonts)
Свойство вошло в Baseline в статусе widely available в мае 2025 года. Теперь его можно использовать в проектах и не переживать о поддержке.
- 18 июня 2025

Как анимировать 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

Как размыть фон под элементом с помощью 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