elementPlus修改主題色以及皮膚設(shè)置思路
elementPlus修改主題色以及皮膚設(shè)置
修改主題色
<el-color-picker style=“margin-top:20px” v-model=“systeamColor” @change=“colorChange” />
采用element顏色選擇的組件
// 變量前綴 colorChange(e) { ?? ?// e就是選擇了的顏色 ?? ?const pre = "--el-color-primary"; ?? ?// 白色混合色 ?? ?const mixWhite = "#ffffff"; ?? ?// 黑色混合色 ?? ?const mixBlack = "#000000"; ?? ?const el = document.documentElement; ?? ?el.style.setProperty(pre, e); ?? ?// 這里是覆蓋原有顏色的核心代碼 ?? ?for (let i = 1; i < 10; i += 1) { ?? ? ?el.style.setProperty(`${pre}-light-${i}`, mix(e, mixWhite, i * 0.1)); ?? ?} ?? ?el.style.setProperty("--el-color-primary-dark", mix(e, mixBlack, 0.1)); }
系統(tǒng)皮膚
通過(guò)提前定義好各種皮膚風(fēng)格
通過(guò)vue的store以及l(fā)ocalStorage去動(dòng)態(tài)修改
同時(shí)代碼中要使用變量方式引入store中的主題顏色
elementPlus修改主題顏色(含暗夜模式切換)
直接調(diào)用 setThemeColor(color) 函數(shù),color 為傳入的主題顏色
export function setThemeColor(color) { const el = document.documentElement; const body = document.querySelector("body"); // const nprogress = document.querySelector("#nprogress .bar"); // console.log(nprogress) el.style.setProperty("--el-color-primary", color); body.style.setProperty("--van-primary-color", color); // nprogress.style.setProperty("background", color); // 此行判斷是否為白天/暗夜模式,可根據(jù)自身業(yè)務(wù)調(diào)整代碼 let mixColor = Store.state.settings.sideTheme.split("-")[1] === "light" ? "#ffffff" : "#000000"; // 此行判斷是否為白天/暗夜模式,可根據(jù)自身業(yè)務(wù)調(diào)整代碼 for (let i = 1; i < 10; i++) { el.style.setProperty(`--el-color-primary-light-${i}`, colourBlend(color, mixColor, i / 10)); el.style.setProperty(`--el-color-primary-dark-${i}`, colourBlend(color, mixColor, i / 10)); } el.style.setProperty(`--el-color-primary-dark-2`, colourBlend(color, mixColor, 0.2)); } export function colourBlend(c1, c2, ratio) { ratio = Math.max(Math.min(Number(ratio), 1), 0) let r1 = parseInt(c1.substring(1, 3), 16) let g1 = parseInt(c1.substring(3, 5), 16) let b1 = parseInt(c1.substring(5, 7), 16) let r2 = parseInt(c2.substring(1, 3), 16) let g2 = parseInt(c2.substring(3, 5), 16) let b2 = parseInt(c2.substring(5, 7), 16) let r = Math.round(r1 * (1 - ratio) + r2 * ratio) let g = Math.round(g1 * (1 - ratio) + g2 * ratio) let b = Math.round(b1 * (1 - ratio) + b2 * ratio) r = ('0' + (r || 0).toString(16)).slice(-2) g = ('0' + (g || 0).toString(16)).slice(-2) b = ('0' + (b || 0).toString(16)).slice(-2) return '#' + r + g + b }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
集成vue到j(luò)query/bootstrap項(xiàng)目的方法
下面小編就為大家分享一篇集成vue到j(luò)query/bootstrap項(xiàng)目的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02vuex中的state、getters、mutations、actions之間的關(guān)系解讀
這篇文章主要介紹了vuex中的state、getters、mutations、actions之間的關(guān)系,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10Element-UI?el-table對(duì)循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式
這篇文章主要介紹了Element-UI?el-table對(duì)循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03vue+element ui實(shí)現(xiàn)錨點(diǎn)定位
這篇文章主要為大家詳細(xì)介紹了vue+element ui實(shí)現(xiàn)錨點(diǎn)定位,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06