文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

基于vue3和element-plus的暗黑模式如何实现

2023-07-06 11:46

关注

这篇文章主要介绍“基于vue3和element-plus的暗黑模式如何实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于vue3和element-plus的暗黑模式如何实现”文章能帮助大家解决问题。

一、基本使用

因为是通过在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>

二、自定义深色样式

暗黑模式中,一旦混入非深色样式,就会非常难看刺眼,一些自定义样式的暗黑模式适配是少不了的

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 {    --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变量

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变量一样使用scss变量,那为何不直接使用css变量呢?况且,css变量还可以使用js更改之

三、暗黑模式下的图片

CodePen上发现的一行代码的方案 Dark mode image filter

其实是通过使用 CSS3 filter 设置图片的亮度、饱和度:

filter: brightness(0.8) saturate(1.25);

在暗黑模式下显示图片,部分会比较亮,刺眼。可以使用CSS滤镜,设置图片的亮度、饱和度

除图片外,可将以图片为背景图的容器加上类 dark-img-bg 或其它css选择器

html.dark {  img,  .dark-img-bg {filter:brightness(0.8) saturate(1.25)}}

关于“基于vue3和element-plus的暗黑模式如何实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯