Переопределяющие переменные CSS
Переопределить глобальную переменную локальной переменной
Из предыдущей страницы мы узнали, что доступ к глобальным переменным и их использование можно получить во всем документе, а локальные переменные можно использовать только внутри селектора, где он объявлен.
Посмотрите на пример с предыдущей страницы:
Пример
:root {
--blue: #1e90ff;
--white: #ffffff;
}
body {
background-color: var(--blue);
}
h2 {
border-bottom: 2px solid var(--blue);
}
.container {
color: var(--blue);
background-color: var(--white);
padding:
15px;
}
button {
background-color: var(--white);
color: var(--blue);
border: 1px solid var(--blue);
padding: 5px;
}
Иногда мы хотим, чтобы переменные менялись только в определенном разделе страницы.
Предположим, нам нужен другой синий цвет для кнопок. Затем мы можем повторно объявить переменную --blue внутри селектора кнопок. Когда мы используем var(--blue) внутри этого селектора, он будет использовать объявленное здесь значение локальной переменной --blue.
Мы видим, что локальная переменная --blue переопределит глобальную переменную --blue для элементов кнопки:
Пример
:root {
--blue: #1e90ff;
--white: #ffffff;
}
body {
background-color: var(--blue);
}
h2 {
border-bottom: 2px solid var(--blue);
}
.container {
color: var(--blue);
background-color: var(--white);
padding:
15px;
}
button {
--blue: #0000ff; /* local variable will
override global */
background-color: var(--white);
color: var(--blue);
border: 1px solid var(--blue);
padding: 5px;
}
Добавить новую локальную переменную
Если переменная должна использоваться только в одном месте, мы могли бы также объявить новую локальную переменную, например:
Пример
:root {
--blue: #1e90ff;
--white: #ffffff;
}
body {
background-color: var(--blue);
}
h2 {
border-bottom: 2px solid var(--blue);
}
.container {
color: var(--blue);
background-color: var(--white);
padding:
15px;
}
button {
--button-blue: #0000ff; /* new local
variable */
background-color: var(--white);
color: var(--button-blue);
border: 1px solid var(--button-blue);
padding: 5px;
}
Поддержка браузера
Цифры в таблице указывают на первую версию браузера, которая полностью поддерживает эту
var()
функцию.
Function | |||||
---|---|---|---|---|---|
var() | 49.0 | 15.0 | 31.0 | 9.1 | 36.0 |
CSS-функция var()
Property | Description |
---|---|
var() | Inserts the value of a CSS variable |