前端开发如何灵活使用 css 变量

🧩 一、CSS 变量的定义与使用基础

定义方式

css 复制代码
:root {
  --primary-color: #409eff;
  --font-size-base: 14px;
}

:root 选择器相当于全局作用域(类似全局变量)。

使用方式

css 复制代码
button {
  color: var(--primary-color);
  font-size: var(--font-size-base);
}

var() 语法:

css 复制代码
color: var(--text-color, #333); /* 第二个参数是默认值 */

⚙️ 二、动态修改 CSS 变量(核心)

CSS 变量是运行时动态的,可以通过 JS 修改而立即生效,无需重新渲染整个页面。

✅ 方法 1:修改根节点变量

javascript 复制代码
document.documentElement.style.setProperty('--primary-color', '#ff4d4f');

✅ 方法 2:修改某个局部作用域

CSS 变量有作用域,可以定义在某个元素上:

css 复制代码
.card {
  --card-bg: white;
  background: var(--card-bg);
}

JS 动态改它:

dart 复制代码
document.querySelector('.card').style.setProperty('--card-bg', '#f5f5f5');

🧭 三、灵活应用场景

1. 主题切换(暗色 / 亮色)

css 复制代码
:root {
  --bg-color: #fff;
  --text-color: #000;
}

[data-theme="dark"] {
  --bg-color: #121212;
  --text-color: #fff;
}

JS 切换:

javascript 复制代码
document.documentElement.setAttribute('data-theme', 'dark');

🔥 推荐做法:通过 data-themeclass 切换主题,CSS 自己处理颜色映射。


2. 响应式设计 + 动态计算

利用 calc()clamp() 等函数与变量结合:

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

.card {
  font-size: calc(var(--base-size) * 1.2);
}

在 JS 中动态调整全局字号:

javascript 复制代码
document.documentElement.style.setProperty('--base-size', '18px');

3. 组件参数化

在组件封装中(如 React / Vue / Web Components),可通过变量让组件样式可配置:

css 复制代码
.my-button {
  --btn-color: #409eff;
  background-color: var(--btn-color);
}

父组件通过 style 传入:

ini 复制代码
<MyButton style="--btn-color: #ff4d4f" />

4. 配合动画 / 动态过渡

CSS 变量可以和 transition 配合使用:

css 复制代码
:root {
  --panel-height: 100px;
}

.panel {
  height: var(--panel-height);
  transition: height 0.3s ease;
}

JS 动态修改:

javascript 复制代码
document.documentElement.style.setProperty('--panel-height', '200px');

面板高度会平滑过渡。


🧠 四、CSS 变量 vs 预处理器变量(LESS/SASS)

特性 CSS变量 LESS/SASS变量
生效时机 运行时 编译时
动态修改 ✅ 可运行时修改 ❌ 需重新编译
可作用域化 ✅ 有作用域(继承) ❌ 全局或局部编译作用域
浏览器支持 ✅ 现代浏览器全支持 ✅ 依赖编译

💡 通常结合使用:

  • LESS 变量负责 编译时样式结构
  • CSS 变量负责 运行时动态主题

🧰 五、实践建议

  1. 定义命名规范:

    css 复制代码
    --color-primary
    --font-size-sm
    --layout-header-height
  2. 建立统一入口文件:
    variables.css 管理所有变量,通过 @import 或构建工具引入。

  3. 避免滥用:

    动态改动频繁的变量可使用 JS 样式或 class 切换,静态主题类变量用 CSS 变量即可。

  4. 可结合存储:

    ini 复制代码
    const theme = 'dark';
    localStorage.setItem('theme', theme);
    document.documentElement.dataset.theme = theme;

🎨 示例:多主题动态切换

xml 复制代码
<style>
  :root {
    --bg: #fff;
    --text: #000;
  }

  [data-theme='dark'] {
    --bg: #1e1e1e;
    --text: #fff;
  }

  body {
    background: var(--bg);
    color: var(--text);
    transition: background 0.3s, color 0.3s;
  }
</style>

<body>
  <button id="toggleTheme">切换主题</button>

  <script>
    const root = document.documentElement;
    document.getElementById('toggleTheme').onclick = () => {
      const isDark = root.dataset.theme === 'dark';
      root.dataset.theme = isDark ? 'light' : 'dark';
    };
  </script>
</body>
相关推荐
qq_1777673741 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头882144 分钟前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
天人合一peng3 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling4 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区4 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO5 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121385 小时前
Vuex介绍
前端·javascript·vue.js
We་ct5 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480066 小时前
【无标题】
开发语言·前端·javascript