在 CSS 中,我们通常会使用一些固定的值来定义样式,比如颜色、字体大小、边距等。但随着项目的不断发展和需求的变化,这些固定值可能会变得难以维护和复用。这就是 CSS 变量(Custom Properties)派上用场的地方。
CSS 变量,也称为自定义属性(Custom Properties),允许我们在 CSS 中定义可重用的值。它们以 --
开头,可以在整个文档中使用。
下面是一个简单的例子:
:root {
--primary-color: #007bff;
--secondary-color: #6c757d;
--font-size: 16px;
}
.button {
background-color: var(--primary-color);
color: #fff;
font-size: var(--font-size);
padding: 10px 20px;
}
.text {
color: var(--secondary-color);
font-size: var(--font-size);
}
在这个例子中,我们在 :root
选择器下定义了三个 CSS 变量:--primary-color
、--secondary-color
和 --font-size
。然后在 .button
和 .text
类中使用 var()
函数引用这些变量。
灵活性:CSS 变量允许我们在不修改 HTML 的情况下,轻松地更改样式。这对于主题切换、响应式布局等场景非常有用。
可读性和维护性:使用有意义的变量名可以让 CSS 代码更加易读和易于维护。
作用域:CSS 变量可以在不同的选择器/元素中定义,具有自己的作用域,这使得样式定义更加灵活。
动态性:CSS 变量可以在 JavaScript 中动态地获取和设置,这为样式的动态修改提供了可能。
性能:与使用 SCSS 等预处理器相比,CSS 变量的性能更好,因为它们是原生支持的。
主题切换:通过定义主题相关的变量,可以轻松地实现暗/亮主题切换。
响应式布局:使用 CSS 变量可以更方便地为不同屏幕尺寸设置样式。
组件库/设计系统:通过定义可复用的变量,可以实现组件库或设计系统中的样式统一。
动态样式:结合 JavaScript,可以实现各种动态的样式效果,如交互式图表、自定义滚动条等。
样式继承:CSS 变量可以被继承,这使得样式定义更加灵活。