验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

基于vue3和element-plus的暗黑模式怎么实现

阅读:1281 来源:乙速云 作者:代码code

基于vue3和element-plus的暗黑模式怎么实现

      一、基本使用

      因为是通过在html标签上添加 dark 类,可以自行实现切换

      但为了方便切换以及进一步的定制化,官方推荐使用 useDark | VueUse

      示例:以下,基于 element-plus switch组件 创建了一个暗黑模式开关组件,将它放入菜单栏,就可以方便地切换模式了

      
      import { useDark, useToggle } from '@vueuse/core'
      
      const isDark = useDark()
      const toggleDark = useToggle(isDark)
      
      
      
      

      二、自定义深色样式

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

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

      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)}
      }
    分享到:
    *特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
    相关文章
    {{ v.title }}
    {{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
    你可能感兴趣
    推荐阅读 更多>