基于 vue3 & element-plus 的暗黑模式
前言
element-plus@2.2.0 已经开始支持暗黑模式了,引入样式文件:
import 'element-plus/theme-chalk/dark/css-vars.css'
通过在html标签上添加一个名为 dark 的类来启用
一、基本使用
因为是通过在html标签上添加 dark 类,可以自行实现切换。
为了方便切换以及进一步的定制化,官方推荐使用 useDark | VueUse
示例:以下,基于 element-plus switch组件 创建了一个暗黑模式开关组件,将它放入菜单栏,就可以方便地切换模式了
<script setup>
import { useDark, useToggle } from '@vueuse/core'
const isDark = useDark()
const toggleDark = useToggle(isDark)
</script>
<template>
<span @click.stop="toggleDark()">暗黑模式</span>
<el-switch size="small" v-model="isDark"/>
</template>
进一步定制化可查阅官方文档
只是引入样式的话,不会自动自动检测系统模式并切换(系统深色模式,打开网页还是浅色模式)
看起来有点“蠢”,但“不自动切换”可能也是很多项目需要的。自动切换也不难实现,“默认浅色+手动切换”应该也有一定需求在
注意:
useDark()引入并使用后,它就会在打开页面时检测系统模式并应用,在系统切换模式时同步模式
二、自定义深色样式
暗黑模式中,一旦混入非深色样式,就会非常难看刺眼,一些自定义样式的暗黑模式适配是少不了的
1、深色样式
element-plus定义了一些暗黑模式下的变量,满足其自身样式的暗黑模式适配
项目中设定了颜色的样式是无法自动适配的,需要我们手动写一套深色样式来覆盖
html.dark {
.my-dialog {
background-color: #304156;
color: #bfcbd9;
}
}2、变量覆盖
一些反复使用的样式可以定义成变量重用,这样,就可以通过简单的变量覆盖来适配暗黑模式
:root {
--theme-color: #409EFF;
}
html.dark {
--theme-color: #135fad;
}
.demo-class {background-color:var(--theme-color)}
.demo-class-one button {color:var(--theme-color)}3、element-plus变量覆盖
如果想更改element-plus默认的深色样式,可再次定义并覆盖之。为了正确覆盖,下述样式需在引入element-plus样式后引入
src/styles/demo.scss:
html.dark {
/* 覆盖element-plus默认深色背景色 */
--el-bg-color: #626aef;
.el-button--primary {
--el-button-text-color: #ededed;
}
}main.js:
import 'element-plus/dist/index.css'
import './styles/demo.scss'4、scss变量
如果只是当作css变量一样使用scss变量,建议直接使用css变量
scss定义变量,并在其它样式中引入使用。结合css变量,也可以轻松实现暗黑模式的适配
src/styles/variables.scss:
$menuBg:var(--menuBg);
$menuActiveText:var(--themeColor);
$btnColor: var(--themeColor);src/styles/index.scss:
@import './variables.scss';
:root {
--themeColor: #409EFF;
--menuBg: #304156;
}
html.dark {
--themeColor: #46ACFF;
--menuBg: #263445;
}main.js:
import './styles/index.scss'三、暗黑模式下的图片
在暗黑模式下显示图片,部分会比较亮,刺眼。可以使用CSS滤镜,设置图片的亮度、饱和度 除图片外,可将以图片为背景图的容器加上类 dark-img-bg 或其它css选择器
html.dark {
img,
.dark-img-bg {filter:brightness(0.8) saturate(1.25)}
}