vue3实现自定义主题色切换功能

目录

1.添加theme样式文件

文件内容如下:

css 复制代码
html[data-theme="light"]{
  --text-color: #000000;
  /* 写需要切换的样式 */
}
html[data-theme="dark"]{
  --text-color: #ffffff;
  /* 写需要切换的样式 */
}

2.引入样式文件

在main.js中引入文件:

javascript 复制代码
import './styles/theme.css'

3.使用变量设置css样式

使用var(自定义的变量名)来设置动态的css样式

css 复制代码
.text {
  color: var(--text-color);
 }

4.设置主题样式

在index.html文件里设置默认样式

5.切换方法

javascript 复制代码
<button @click="changeTheme">切换</button>
const theme = ref('dark')
const changeTheme = () =>{
	document.documentElement.setAttribute("data-theme", theme.value == "dark" ? "light" : "dark")
	theme.value = theme.value == 'dark' ? 'light' : 'dark'
}
相关推荐
追逐时光者1 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
如果超人不会飞1 小时前
脉络清晰的业务演进:TinyVue Timeline 时间线组件全方位实战指南
vue.js
如果超人不会飞1 小时前
从扁平到立体:掌握 TinyVue Grid 树形表格的高级实战指南
vue.js
Asmewill3 小时前
grep&curl命令学习笔记
前端
stringwu3 小时前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
用户2136610035724 小时前
Vue2组件化开发与父子通信
前端·vue.js
Momo__5 小时前
TypeScript satisfies 操作符——比 as 更安全的类型守门员
前端·typescript
用户2136610035725 小时前
Vue2事件系统与指令进阶
前端·vue.js
labixiong5 小时前
实现一个能跑的迷你版Promise(一)
前端·javascript·面试
Csvn7 小时前
`??` 和 `||` 搞混,线上用户头像全挂了
前端