elementPlus修改主题色以及皮肤设置思路
更新时间:2023年04月20日 08:55:17 作者:小张很嚣张~
这篇文章主要介绍了elementPlus修改主题色以及皮肤设置思路,具有很好的参考价值,希望对大家有所帮助。
elementPlus修改主题色以及皮肤设置
修改主题色
<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)); }
系统皮肤
通过提前定义好各种皮肤风格
通过vue的store以及localStorage去动态修改
同时代码中要使用变量方式引入store中的主题颜色
elementPlus修改主题颜色(含暗夜模式切换)
直接调用 setThemeColor(color) 函数,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); // 此行判断是否为白天/暗夜模式,可根据自身业务调整代码 let mixColor = Store.state.settings.sideTheme.split("-")[1] === "light" ? "#ffffff" : "#000000"; // 此行判断是否为白天/暗夜模式,可根据自身业务调整代码 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 }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
如何使用Vue3.2+Vite2.7从0快速打造一个UI组件库
构建工具使用vue3推荐的vite,下面这篇文章主要给大家介绍了关于如何使用Vue3.2+Vite2.7从0快速打造一个UI组件库的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-09-09在elementui中Notification组件添加点击事件实例
这篇文章主要介绍了在elementui中Notification组件添加点击事件实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-11-11Vue3 openlayers加载瓦片地图并手动标记坐标点功能
这篇文章主要介绍了 Vue3 openlayers加载瓦片地图并手动标记坐标点功能,我们这里用vue/cli创建,我用的node版本是18.12.1,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下2024-04-04Vue突然报错doesn‘t work properly without JavaScript enabled
最近在做项目的时候遇到了些问题,所以这篇文章主要给大家介绍了关于Vue突然报错doesn‘t work properly without JavaScript enabled的解决方法,需要的朋友可以参考下2023-01-01
最新评论