深入理解CSS变量(Custom Properties)

1. 基础概念与语法

CSS变量也称为CSS自定义属性,使用--前缀定义:

css 复制代码
:root {
--main-color: #3498db;
--padding: 15px;
}

.element {
background-color: var(--main-color);
padding: var(--padding);
}

特性:

  • --开头命名(如--main-color
  • 大小写敏感
  • 使用var()函数调用变量
  • 可以设置默认值:var(--color, red)

2. 作用域与优先级

CSS变量遵循CSS层叠规则:

css 复制代码
:root {
--size: 16px;
}

.container {
--size: 14px; /* 局部覆盖 */
}

.text {
font-size: var(--size); /* 在.container内是14px,外部是16px */
}

作用域图解:

3. JavaScript动态交互

JavaScript可以实时读取和修改CSS变量:

javascript 复制代码
// 获取变量
const root = document.documentElement;
const color = getComputedStyle(root).getPropertyValue('--main-color');

// 修改变量
root.style.setProperty('--main-color', 'red');

// 动态响应式示例
window.addEventListener('resize', () => {
const fontSize = window.innerWidth < 600 ? '14px' : '16px';
root.style.setProperty('--base-size', fontSize);
});

4. 实战应用案例

案例1:主题切换

css 复制代码
:root {
--bg-primary: #ffffff;
--text-primary: #333333;
}

.dark-mode {
--bg-primary: #222222;
--text-primary: #f0f0f0;
}

body {
background: var(--bg-primary);
color: var(--text-primary);
transition: all 0.3s;
}

案例2:响应式间距系统

css 复制代码
:root {
--spacing: 8px;
}

@media (min-width: 768px) {
:root {
 --spacing: 16px;
}
}

.card {
margin: var(--spacing);
padding: calc(var(--spacing) * 2);
}

5. 性能优化建议

  1. 避免过度嵌套:深层次的变量引用会增加解析时间
  2. 合理作用域:将变量定义在尽可能接近使用的地方
  3. 动态变量慎用:频繁通过JS更新的变量可能引起重排
  4. 预处理器对比:比LESS/SASS变量具有运行时可变的优势
  5. 兼容性处理:提供fallback值
css 复制代码
/* 推荐写法 */
.element {
color: var(--primary-color, blue); /* 添加默认值 */
font-size: var(--text-size, 16px);
}
相关推荐
lbh1 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
We་ct2 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
qq_406176142 小时前
深入浅出 Pinia:Vue3 时代的状态管理新选择
javascript·vue.js·ecmascript
wefly20172 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒3 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro3 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳3 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授3 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
叫我一声阿雷吧4 小时前
JS 入门通关手册(23):JS 异步编程:回调函数与异步本质
javascript·es6·前端面试·回调函数·回调地狱·js异步编程·异步本质
zayzy4 小时前
前端八股总结
开发语言·前端·javascript