6 фрагментов CSS, которые должен знать каждый фронтенд-разработчик в 2023 году

Надежный, мощный и стабильный CSS-код, который вы можете использовать уже сегодня.

Я считаю, что каждый фронтенд-разработчик должен уметь использовать контейнерные запросы , создавать фиксацию прокрутки , избегать использования position: absolute в сетке , быстро создавать круги, применять каскадные слои и добиваться большего с меньшими затратами с помощью логических свойств . Вот краткий обзор каждого из этих требований.

1. Запрос контейнера

Самая востребованная функция CSS на протяжении 10 лет подряд теперь стабильно работает во всех браузерах и доступна для использования с запросами ширины в 2023 году.

.panel {
  container: layers-panel / inline-size;
}

.card {
  padding: 1rem;
}

@container layers-panel (min-width: 20rem) {
  .card {
    padding: 2rem;
  }
}
@container

Browser Support

  • Chrome: 105.
  • Edge: 105.
  • Firefox: 110.
  • Сафари: 16.

Source

container

Browser Support

  • Chrome: 105.
  • Edge: 105.
  • Firefox: 110.
  • Сафари: 16.

Source

2. Привязка к прокрутке

Грамотно организованная прокрутка выделяет ваш пользовательский опыт среди остальных, а функция привязки прокрутки — идеальный способ согласовать пользовательский интерфейс с прокруткой системы, обеспечивая при этом удобные точки остановки.

.snaps {
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  overscroll-behavior-x: contain;
}

.snap-target {
  scroll-snap-align: center;
}

.snap-force-stop {
  scroll-snap-stop: always;
}

Узнайте больше о потенциале этой функции CSS в этой огромной и вдохновляющей коллекции Codepen, содержащей около 25 демонстрационных примеров.

scroll-snap-type

Browser Support

  • Chrome: 69.
  • Край: 79.
  • Firefox: 99.
  • Сафари: 11.

Source

scroll-snap-align

Browser Support

  • Chrome: 69.
  • Край: 79.
  • Firefox: 68.
  • Сафари: 11.

Source

scroll-snap-stop

Browser Support

  • Chrome: 75.
  • Край: 79.
  • Firefox: 103.
  • Сафари: 15.

Source

overscroll-behavior

Browser Support

  • Chrome: 144.
  • Край: 18.
  • Firefox: 150.
  • Сафари: 16.

Source

3. Сетчатая свая

Избегайте использования свойства `position: absolute` при работе с одноячеечной CSS-сеткой. После того, как ячейки наложены друг на друга , используйте свойства `justify` и `align` для их позиционирования.

.pile {
  display: grid;
  place-content: center;
}

.pile > * {
  grid-area: 1/1;
}
grid

Browser Support

  • Chrome: 57.
  • Край: 16.
  • Firefox: 52.
  • Safari: 10.1.

Source

4. Быстрый круг

Существует множество способов создания кругов в CSS, но этот, безусловно, самый минималистичный.

.circle {
  inline-size: 25ch;
  aspect-ratio: 1;
  border-radius: 50%;
}
aspect-ratio

Browser Support

  • Chrome: 88.
  • Край: 88.
  • Firefox: 89.
  • Сафари: 15.

Source

5. Контрольные варианты с помощью @layer

Каскадные слои могут помочь вставить варианты, обнаруженные или созданные позже, в нужное место в каскаде вместе с исходным набором вариантов.

/* file buttons.css */
@layer components.buttons {
  .btn.primary {
    
  }
}

Затем, в совершенно другом файле, загруженном в другое случайное время, добавьте новый вариант к слою кнопки, как если бы он всё это время присутствовал там вместе с остальными.

/* file video-player.css */
@layer components.buttons {
  .btn.player-icon {
    
  }
}
@layer

Browser Support

  • Chrome: 99.
  • Край: 99.
  • Firefox: 97.
  • Сафари: 15.4.

Source

6. Меньше запоминайте и больше достигайте, используя логические свойства.

Запомните эту новую модель оформления , и вам больше никогда не придется беспокоиться об изменении левого и правого отступа или поля для международных режимов письма и направлений документа . Настройте стили, перейдя от физических свойств к логическим, таким как padding-inline , margin-inline , inset-inline , и теперь браузер сам выполнит необходимые настройки.

button {
  padding-inline: 2ch;
  padding-block: 1ch;
}

article > p {
  text-align: start;
  margin-block: 2ch;
}

.something::before {
  inset-inline: auto 0;
}
padding-inline

Browser Support

  • Chrome: 87.
  • Край: 87.
  • Firefox: 66.
  • Сафари: 14.1.

Source

margin-block

Browser Support

  • Chrome: 87.
  • Край: 87.
  • Firefox: 66.
  • Сафари: 14.1.

Source

inset-inline

Browser Support

  • Chrome: 87.
  • Край: 87.
  • Firefox: 63.
  • Сафари: 14.1.

Source