前端开发如何灵活使用 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>
相关推荐
d***9353 小时前
springboot3.X 无法解析parameter参数问题
android·前端·后端
n***84074 小时前
十七:Spring Boot依赖 (2)-- spring-boot-starter-web 依赖详解
前端·spring boot·后端
likuolei8 小时前
XSL-FO 软件
java·开发语言·前端·数据库
正一品程序员8 小时前
vue项目引入GoogleMap API进行网格区域圈选
前端·javascript·vue.js
j***89468 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
star_11128 小时前
Jenkins+nginx部署前端vue项目
前端·vue.js·jenkins
im_AMBER8 小时前
Canvas架构手记 05 鼠标事件监听 | 原生事件封装 | ctx 结构化对象
前端·笔记·学习·架构
JIngJaneIL8 小时前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·农产品电商系统
Tongfront8 小时前
前端通用submit方法
开发语言·前端·javascript·react
可爱又迷人的反派角色“yang”8 小时前
LVS+Keepalived群集
linux·运维·服务器·前端·nginx·lvs