Автор курса «HTML-верстка» Стас Мельников рассказал, что такое пользовательские CSS-свойства и почему их стоит изучить.

Обучение в онлайн-университете: курс «Старт в программировании»

Стандарт CSS Custom Properties изменил CSS. Появились безумные возможности, о которых раньше мы могли только мечтать. Рассказываем, какие именно и почему новичкам стоит изучить их как можно быстрее.

Что такое пользовательское свойство

Пользовательское свойство — это CSS-свойство, которое создал сам разработчик. Браузер ничего не знает о таком свойстве, пока его не объявили.

Объявление пользовательского свойства начинается с двойного дефиса, после которого указывают название, ставят двоеточие и добавляют значение.

Введение в пользовательские CSS-свойства

Для примера объявим пользовательское свойство nopk netologyBrandColor со значением purple для элемента button:

button {

nopk netologyBrandColor: purple,

}

Теперь браузер знает о нашем свойстве, но в чем его польза?

Особенности пользовательских свойств

Первая фишка — функция var. С помощью этой функции мы можем сказать браузеру, чтобы он взял значение из объявленного пользовательского свойства и добавил его для встроенного свойства.

Чтобы браузер так сделал, разработчику нужно объявить встроенное свойство, например, color, и добавить к нему в качестве значения функцию var, в аргументе которой передать название пользовательского свойства.

Введение в пользовательские CSS-свойства

Для примера добавим пользовательское свойство для встроенных свойств border и color:

button {

nopk netologyBrandColor: purple,

border: 2px solid var(nopk netologyBrandColor),

color: var(nopk netologyBrandColor),

}

В браузере кнопка будет выглядеть так:

Введение в пользовательские CSS-свойства

Зачем изучать пользовательские свойства, если есть переменные в Sass и они полностью устраивают?

Переменные в препроцессорах, таких как LESS и Sass, помогают организовать код, чтобы нам было проще поддерживать его. Например, в следующем коде я использую переменную $nopk netologyBrandColor, в которой хранится основной цвет бренда:

$nopk netologyBrandColor: purple,

button {

border: 2px solid $nopk netologyBrandColor,

color: $nopk netologyBrandColor,

}

После преобразования кода в браузере мы увидим следующий код:

button {

border: 2px solid purple,

color: purple,

}

Исходя из примера, понятно, что после преобразования кода из Sass в CSS на место переменных компилятор вставил их значения, поэтому мы можем сказать, что Sass-переменных нет в браузере.

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

button {

nopk netologyBrandColor: purple,

border: 2px solid var(nopk netologyBrandColor),

color: var(nopk netologyBrandColor),

}

button:hover {

nopk netologyBrandColor: #27ae60,

}

Введение в пользовательские CSS-свойства

Теперь, если у кнопки сработает состояние hover, значения у свойств border и color изменятся. Именно из-за этой особенности пользовательские свойства и называют «живыми»: они могут изменяться прямо в браузере, и соответственно менять значения встроенных свойств, к которым они применяются.

В качестве еще одного примера изменю значение пользовательского свойства при состоянии focus.

button {

nopk netologyBrandColor: #000000,

border: 2px solid var(nopk netologyBrandColor),

color: var(nopk netologyBrandColor),

}

button:hover {

nopk netologyBrandColor: #27ae60,

}

button:focus {

nopk netologyBrandColor: #c0392b,

outline: 3px solid var(nopk netologyBrandColor),

}

Введение в пользовательские CSS-свойства

Способность динамического изменения пользовательских свойства можно сочетать с Sass-переменными или LESS-переменными.

Пользовательские свойства и media-выражения

Еще одна возможность пользовательских свойств — их значения можно переключать с помощью медиазапросов.

Для примера создадим два пользовательских свойства: —mq и —textColor. При помощи первого выведем название медиафункции на страницу, а второе нужно для переключения цвета. На экранах с шириной до 768px текст будет пурпурным, а от 769px — красным.

body::before {

content: var(mq),

color: var(textColor),

}

@media (max-width: 768px) {

body::before {

mq: max-width: 768px,

textColor: purple,

}

}

@media (min-width: 769px) {

body::before {

mq: min-width: 769px,

textColor: red,

}

}

Введение в пользовательские CSS-свойстваВведение в пользовательские CSS-свойства

Пользовательские свойства и функция calc

В CSS есть функция calc, с помощью которой можно выполнять арифметические операции. Она также может работать и с пользовательскими свойствами. Например, мы можем контролировать количество дочерних элементов в ряду:

.child {

width: calc(100% / var(childCount)),

}

Если добавить значение 5 для пользовательского свойства childCount в браузере, увидим следующую картину:

Введение в пользовательские CSS-свойства

Для разнообразия изменю 5 на 7 и элементы перестроятся.

Введение в пользовательские CSS-свойства

Пользовательские свойства и SVG

Еще одна возможность пользовательских свойств — с их помощью можно задать значение для таких SVG-свойств, как fill, stroke, stroke-width и других. Это можно сделать двумя способами.

В первом способе будем использовать атрибуты fill, stroke и stroke-width, к которым в качестве значения определим пользовательские свойства.

<,svg class=svg-with-attr viewBox=0 0 26 28>,

<,path stroke=var(iconStroke) stroke-width=var(iconStrokeWidth) fill=var(iconFill) d=>,

<,/svg>,

И добавим в CSS значения для пользовательских свойств:

.svg-with-attr{

iconFill: #eeeeee,

iconStroke: #000000,

iconStrokeWidth: 1px,

}

Введение в пользовательские CSS-свойства

Слева иконка без стилизации, а справа с нашими настройками. Вот так просто мы можем настраивать графику.

Второй способ — убрать атрибуты их и заменить на CSS-свойства.

<,svg class=svg-with-props viewBox=0 0 26 28>,

<,path d=>,

<,/svg>,

.svg-with-props {

iconFill: #ffcc00,

iconStroke: #000000,

iconStrokeWidth: 2px,

stroke: var(iconStroke),

stroke-width: var(iconStrokeWidth),

fill: var(iconFill),

}

Введение в пользовательские CSS-свойства

Я специально добавил для свойств fill, stroke и stroke-width другие значение, чтобы визуально была заметна разница между примерами.

Поддержка браузерами

Согласно caniuse.com, пользовательские свойства работают в большинстве современных браузеров, кроме IE11.

Введение в пользовательские CSS-свойства

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

Если же вам не нужно поддерживать IE11, смело используйте все возможности пользовательских свойств.

Заключение

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

Читать еще: «Как создавать адаптивные кнопки и блоки в CSS»

Мнение автора и редакции может не совпадать. Хотите написать колонку для «Нетологии»? Читайте наши условия публикации. Чтобы быть в курсе всех новостей и читать новые статьи, присоединяйтесь к Телеграм-каналу Нетологии.

Оцените статью

Средняя оценка 0 / 5. Всего проголосовало 0

Телеграм Нетологии
 

Добавить комментарий


Помогла статья? Оцените её!
0 из 5. Общее количество голосов - 0