CSS использует разные единицы измерения для задания размеров, отступов, шрифтов и других свойств. Разделяют абсолютные и относительные единицы. Понимание различий между ними — фундаментальная основа адаптивной, масштабируемой и удобной в поддержке вёрстки.

Абсолютные:

  • px — пиксели
  • cm — сантиметры
  • mm — миллиметры
  • in — дюймы
  • pt — типографские пункты
  • pc — пика

Относительные:

  • z% — процент от родителя
  • em — от размера шрифта родителя
  • rem — от размера шрифта корня
  • vw — 1% от ширины вьюпорта
  • vh — 1% от высоты вьюпорта
  • vmin / vmax — минимальное/максимальное из vw и vh
  • fr — доля пространства в грид-сетке
  • 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

Грамотное сочетание единиц делает вашу вёрстку гибкой, адаптивной и масштабируемой.