主题切换实际上就是改变项目的主题色,所以我们从css 入手。 在使用到主题色的地方,就不能写固定值(譬如#fff)了,应该用css变量 替换固定值。
原生的css是支持定义变量的,不像sass和less中定义的变量,它无需编译、支持继承和重叠
css变量写法如下:
js
:root {
--background-color: white; // 主题色
--font-color: black; // 字体颜色
}
// 等同于上面
html {
--background-color: white; // 主题色
--font-color: black; // 字体颜色
}
:root,它是css中的一个伪类选择器,代表文档的根元素,等同于html,但是优先级比html高
定义好主题色的css变量后在需要的地方使用它
js
<style>
#app {
background: var(--background-color);
}
</style>
当切换主题时需要更新css变量的值,我们可以利用css样式优先级的特性来实现,在:root后定义如下样式
js
:root {
--background-color: white;
--font-color: black;
}
/* [data-theme='dark']代表含有data-theme属性并且值为'dark'的标签。此处dark代表深色主题,默认:root浅色主题 */
[data-theme='dark'] {
--background-color: black;
--font-color: white;
}
接下来我们只需要在使用了主题色的标签或上级标签 中添加data-theme属性并动态更改它的值,就能实现主题切换。
完整代码如下
js
<template>
<div id="app" :data-theme="curTheme">
<button class="btn" @click="ToggleTheme">切换主题</button>
</div>
</template>
<script>
export default {
name: 'App',
data() {
return {
curTheme: 'light'
}
},
methods: {
ToggleTheme() {
this.curTheme = this.curTheme === 'light' ? 'dark' : 'light'
}
}
}
</script>
<style>
* {
margin: 0;
padding: 0;
}
:root {
--background-color: white;
--font-color: black;
}
[data-theme='dark'] {
--background-color: black;
--font-color: white;
}
.btn {
width: 100px;
height: 30px;
background-color: var(--background-color);
color: var(--font-color);
border: 1px solid var(--font-color);
}
#app {
display: flex;
justify-content: center;
align-items: center;
width: 100vw;
height: 100vh;
background: var(--background-color);
}
</style>