如何在unocss中使用css变量

前言

最近遇到一个需求,在unocss中使用变量(本人项目uniapp + vite + ts + unocss + scss)实现动态去切换页面风格,当然你也可以选择手写样式引用scss变量或者less变量,然而我并不想写~ 🤔

unocss本身是不能直接使用变量作为选择器或类名的,(具体原因自己去看unocss,啰啰嗦嗦下不了班了🤣),但是可以使用css变量,利用var函数是可以实现,直接上招咯~

* 将uniapp中已有uni.scss生成uni.css

(当然你勤快的话,也可以一个个手敲👍,弊端我就不说了,自己酝~),上代码👇

js 复制代码
const fs = require('fs')
const path = require('path')
// 读取uni.scss
const scssContent = fs.readFileSync('./src/uni.scss', 'utf8')
// 由scss变量生成css变量(less变量自己看着调一下就行)
const scss2Css = () => {
  // 使用正则表达式提取 SCSS 变量
  const variableRegex = /\$([\w-]+):\s*([^;]+)(?=[;\s]|$)/g
  let cssVariables = ''
  let match
  while ((match = variableRegex.exec(scssContent)) !== null) {
    // 变量名
    const variableName = match[1].replace(/[A-Z]/g, '-$&').toLowerCase()
    // 变量值
    const variableValue = match[2].trim()
    // 转换为 CSS 自定义属性
    cssVariables += `--${variableName}: ${variableValue};\n`
  }
  // 生成 CSS 内容
  const cssContent = `:root { ${cssVariables} }`.trim()
  // 写入 CSS 文件
  fs.writeFileSync(path.join(__dirname, './src/uni.css'), cssContent, 'utf8')
}
scss2Css()

下面是由uni.scss生成的css变量文件

在入口文件中引入生成的uni.css

我是在main中引入的

在代码中使用css变量

csharp 复制代码
*记住方括号和var函数别掉了*
  • 效果

写完啦,是不是贼简单~,自己在项目中灵活运用,第一次写文章,略感羞涩,不喜勿喷,后续会陆陆续续写一写自己踩过的坑,也欢迎佬们多多指教,有不足之处,虚心接受佬们赐教!

预告

下一篇想写一写vue路由二级以上路由缓存问题,好久没写业务了,不知道这个问题还有没有,long long ago这个问题困扰过我,不过顺利完成项目交付啦~😉

相关推荐
棋鬼王3 分钟前
Cesium(十) 动态修改白模颜色、白模渐变色、白模光圈特效、白模动态扫描光效、白模着色器
前端·javascript·vue.js·智慧城市·数字孪生·cesium
酉鬼女又兒6 分钟前
零基础快速入门前端蓝桥杯Web备考:BOM与定时器核心知识点详解(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
ThridTianFuStreet小貂蝉6 分钟前
面试题1:请系统讲讲 Vue2 与 Vue3 的核心差异(响应式、API 设计、性能与编译器)。
前端·javascript·vue.js
俊劫11 分钟前
AI Harness - 2026 AI 工程新范式
前端·openai·ai编程
前端付豪28 分钟前
Prompt Playground(实现提示词工作台)
前端·人工智能·后端
竹林81828 分钟前
在NFT项目中集成IPFS:从Pinata上传到前端展示的完整实战与踩坑
前端·javascript
取名不易28 分钟前
canves实现画布
前端
AlkaidSTART31 分钟前
深入浅出 React Hooks 原理:从 Fiber 的 memoizedState 链表讲到 updateQueue 调度
前端
一颗小行星34 分钟前
Harness Engineering 前端开发的下一个阶段
前端·ai编程
踩着两条虫1 小时前
重磅!这款AI低代码平台火了:拖拽生成应用,一键输出Web/H5/UniApp
前端·低代码·ai编程