欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于vue3&element-plus的暗黑模式實例詳解

 更新時間:2022年12月12日 15:21:36   作者:ymzhaoUSTB  
實現(xiàn)暗黑主題的方式有很多種,也有很多成型的框架可以直接使用,下面這篇文章主要給大家介紹了關(guān)于基于vue3&element-plus的暗黑模式的相關(guān)資料,需要的朋友可以參考下

前言

element-plus@2.2.0 已經(jīng)開始支持暗黑模式

通過在html標(biāo)簽上添加一個名為 dark 的類來啟用

基于 vue3 & element-plus 的項目現(xiàn)在可以方便的添加暗黑模式

一、基本使用

因為是通過在html標(biāo)簽上添加 dark 類,可以自行實現(xiàn)切換

但為了方便切換以及進(jìn)一步的定制化,官方推薦使用 useDark | VueUse

示例:以下,基于 element-plus switch組件 創(chuàng)建了一個暗黑模式開關(guān)組件,將它放入菜單欄,就可以方便地切換模式了

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

進(jìn)一步定制化可查閱官方文檔

二、自定義深色樣式

暗黑模式中,一旦混入非深色樣式,就會非常難看刺眼,一些自定義樣式的暗黑模式適配是少不了的

1、深色樣式

element-plus定義了一些暗黑模式下的變量,滿足其自身樣式的暗黑模式適配

項目中設(shè)定了顏色的樣式是無法自動適配的,需要我們手動寫一套深色樣式來覆蓋

html.dark {
  .my-dialog {
    background-color: #304156;
    color: #bfcbd9;
  }
}

2、變量覆蓋

一些反復(fù)使用的樣式可以定義成變量重用,這樣,就可以通過簡單的變量覆蓋來適配暗黑模式

: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默認(rèn)的深色樣式,可再次定義并覆蓋之。為了正確覆蓋,下述樣式需在引入element-plus樣式后引入

src/styles/demo.scss:

html.dark {
  /* 覆蓋element-plus默認(rèn)深色背景色 */
  --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定義變量,并在其它樣式中引入使用。結(jié)合css變量,也可以輕松實現(xiàn)暗黑模式的適配

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'

話說回來,如果只是當(dāng)作css變量一樣使用scss變量,那為何不直接使用css變量呢?況且,css變量還可以使用js更改之

三、暗黑模式下的圖片

CodePen上發(fā)現(xiàn)的一行代碼的方案 Dark mode image filter

其實是通過使用 CSS3 filter 設(shè)置圖片的亮度、飽和度:

filter: brightness(0.8) saturate(1.25);

在暗黑模式下顯示圖片,部分會比較亮,刺眼??梢允褂肅SS濾鏡,設(shè)置圖片的亮度、飽和度

除圖片外,可將以圖片為背景圖的容器加上類 dark-img-bg 或其它css選擇器

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

總結(jié)

到此這篇關(guān)于基于vue3&amp;element-plus暗黑模式的文章就介紹到這了,更多相關(guān)vue3 element-plus暗黑模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue3如何添加eslint校驗(eslint-plugin-vue)

    vue3如何添加eslint校驗(eslint-plugin-vue)

    這篇文章主要介紹了vue3如何添加eslint校驗(eslint-plugin-vue),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue結(jié)合原生js實現(xiàn)自定義組件自動生成示例

    Vue結(jié)合原生js實現(xiàn)自定義組件自動生成示例

    這篇文章主要介紹了Vue結(jié)合原生js實現(xiàn)自定義組件自動生成示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 基于vue實現(xiàn)分頁/翻頁組件paginator示例

    基于vue實現(xiàn)分頁/翻頁組件paginator示例

    本篇文章主要介紹了基于vue實現(xiàn)分頁/翻頁組件paginator示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • vue修改proxyTable解決跨域請求,報404的問題及解決

    vue修改proxyTable解決跨域請求,報404的問題及解決

    這篇文章主要介紹了vue修改proxyTable解決跨域請求,報404的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Element-ui upload上傳文件限制的解決方法

    Element-ui upload上傳文件限制的解決方法

    這篇文章主要介紹了Element-ui upload上傳文件限制的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • vue中使用event.target.value踩坑記錄

    vue中使用event.target.value踩坑記錄

    這篇文章主要介紹了vue中使用event.target.value踩坑記錄,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3?封裝擴(kuò)展并簡化Vuex在組件中的調(diào)用問題

    Vue3?封裝擴(kuò)展并簡化Vuex在組件中的調(diào)用問題

    這篇文章主要介紹了Vue3?封裝擴(kuò)展并簡化Vuex在組件中的調(diào)用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • vue使用vite配置跨域以及環(huán)境配置詳解

    vue使用vite配置跨域以及環(huán)境配置詳解

    跨域是指當(dāng)一個資源去訪問另一個不同域名或者同域名不同端口的資源時,就會發(fā)出跨域請求,下面這篇文章主要給大家介紹了關(guān)于vue使用vite配置跨域以及環(huán)境配置的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • Nuxt的動態(tài)路由和參數(shù)校驗操作

    Nuxt的動態(tài)路由和參數(shù)校驗操作

    這篇文章主要介紹了Nuxt的動態(tài)路由和參數(shù)校驗操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue3手動封裝彈出框組件message的方法

    vue3手動封裝彈出框組件message的方法

    這篇文章主要為大家詳細(xì)介紹了vue3手動封裝彈出框組件message的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論