Vue3 组件中使用 SCSS 变量

在 JavaScript 中不能直接使用 SCSS 变量。但是可以通过一些间接的方法来实现类似的效果。

一、使用 sass-extract

使用 sass-extract 库来提取 SCSS 变量并生成 JSON 文件,然后在 JavaScript 中读取这个 JSON 文件来获取变量值。

1. 安装 sass-extract

bash 复制代码
npm install sass-extract --save-dev

2. 在项目的根目录创建一个 extract-vars.js 文件

这个脚本会读取`./src/styles/main.scss`文件中的 SCSS 变量,并将它们输出到`./src/variables.json`文件中。

javascript 复制代码
const sassExtract = require("sass-extract");

const extractor = sassExtract();



extractor.loadFile("./src/styles/main.scss");

const variables = extractor.vars();

const fs = require("fs");



fs.writeFileSync("./src/variables.json", JSON.stringify(variables, null, 2));

3. 在你的 JavaScript 文件中引入生成的 JSON 文件

javascript 复制代码
const variables = require("./variables.json");



console.log(variables["$primary-color"]); // 假设在 SCSS 中有一个 $primary-color 变量

这种方法需要在构建过程中运行`extract-vars.js`脚本,以确保变量 JSON 文件是最新的。

二、使用 xxx.module.scss

定义 xxx.module.scss 文件, 使用 :export { // ... } 导出 scss 变量给 Vue3

1. 定义 theme.module.scss

css 复制代码
$color--active: #4f7eff;



:export {

  color--active: $color--active;

}

2. 使用

javascript 复制代码
import themeScss from "@/assets/scss/theme.module.scss";



console.log(themeScss);
相关推荐
诸葛大钢铁1 分钟前
如何降低Word文件的体积?压缩Word文件的三种方法
开发语言·c#
小白学大数据2 分钟前
如何自动追踪 eBay 售价?Python 爬虫实战解析
开发语言·人工智能·爬虫·python
莫逸风5 分钟前
【AgentScope】6.文件系统(Filesystem)详解
开发语言·windows·springai·agentscope·agnet
utf8mb4安全女神6 分钟前
怎么写shell/bash脚本【if嵌套】【case】【while死循环】【while嵌套if】【for】【随机数】
开发语言·bash
ziyue75759 分钟前
python进行磁盘文件迁移,不影响软件使用
开发语言·数据库·python
怕浪猫12 分钟前
Electron 开发实战(十二):安全性最佳实践|彻底杜绝漏洞、代码执行与数据泄露
前端·javascript·electron
爱和冰阔落15 分钟前
【Python基础】从变量到面向对象:打通 Python 入门核心语法
开发语言·python
凡人叶枫20 分钟前
Effective C++ 条款05:了解 C++ 默默编写并调用哪些函数
java·linux·开发语言·c++·effective c++·编程范式
少司府22 分钟前
C++进阶:AVL树
开发语言·数据结构·c++·二叉树·avl树
wgc2k25 分钟前
NestJS基础-7: 官方 CLI 完整使用指南
前端