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

Kate

Administrator
Команда форума

Вступление​

Мощные и стабильные CSS фичи, которые вы можете использовать уже сегодня.
Я считаю, что каждый front-end разработчик должен знать, как использовать container query, создавать привязку к прокрутке, избегать position: absolute с помощью grid, быстро создавать круг, использовать каскадные слои и достигать большего с помощью логических свойств. Эта статья — описание каждой из 6 новых возможностей CSS.

1. Container query​

Самая востребованная функция CSS на протяжении 10 лет подряд теперь стабильна в браузерах и доступна для использования в запросах ширины в 2023 году.
.panel {
container: layers-panel / inline-size;
}

.card {
padding: 1rem;
}

@container layers-panel (min-width: 20rem) {
.card {
padding: 2rem;
}
}
CodePen
Узнайте больше о возможностях этой функции CSS в этой огромной и вдохновляющей коллекции Codepen, включающей около 25 демонстрационных примеров.
8f96b95876351706286b6f0a401c07c4.png

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;
}
CodePen
65daa4c34d018b511837ff7099c7ff28.png

3. Избегаем position: absolute с помощью grid​

Избегайте абсолютного позиционирования при использовании CSS grid с одной ячейкой. Когда они будут наложены друг на друга, используйте свойства justify и align для их позиционирования.
.pile {
display: grid;
place-content: center;
}

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

4. Быстро делаем круг​

Существует множество способов создания кругов в CSS, но этот, безусловно, самый минимальный.
.circle {
inline-size: 25ch;
aspect-ratio: 1;
border-radius: 50%;
}
CodePen
032fc815845e1fc250ad28a18a95d3b6.png

5. Каскадные слои​

Каскадные слои могут помочь вставить участки кода, обнаруженные или созданные позже, в нужное место в каскаде с исходным набором вариантов.
/* file buttons.css */
@layer components.buttons {
.btn.primary {

}
}
Затем, в каком-то совершенно другом файле, загруженном в другое случайное время, добавьте новый код к слою кнопок, как будто он был там с остальными все это время.
/* file video-player.css */
@layer components.buttons {
.btn.player-icon {

}
}
CodePen
83cbb2615a0caf0e00d52dd5745b2113.png

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;
}
CodePen
81983a3b68c93785c0b06d26cbe109a6.png



 
Сверху