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
Грамотное сочетание единиц делает вашу вёрстку гибкой, адаптивной и масштабируемой.