开发工具:vue3 + ts + vite + elementplus
最近突然间主题色不见了,恢复到了默认情况,可能是配置的vite自定义引入及其它相关的配置,导致的问题。结果用动态改变主题色来实现改变主题了,先看下代码。
src/hooks/useTheme.ts
- // 文件:src/hooks/useTheme.ts
- // import { useTheme } from "@/hooks/useTheme"; //引入主题勾子
- // const { changeThemeColor } = useTheme(); // 解构功能
-
- import { ElMessage } from 'element-plus'
-
- /**
- * 颜色转换函数
- * @method hexToRgb hex 颜色转 rgb 颜色
- * @method rgbToHex rgb 颜色转 Hex 颜色
- * @method getDarkColor 加深颜色值
- * @method getLightColor 变浅颜色值
- */
- export function useTheme() {
- // str 颜色值字符串
- const hexToRgb = (str: string): any => {
- let hexs: any = ''
- let reg = /^\#?[0-9A-Fa-f]{6}$/
- if (!reg.test(str)) {
- ElMessage.warning('输入错误的hex')
- return ''
- }
- str = str.replace('#', '')
- hexs = str.match(/../g)
- for (let i = 0; i < 3; i++) hexs[i] = parseInt(hexs[i], 16)
- return hexs
- }
- // r 代表红色 | g 代表绿色 | b 代表蓝色
- const rgbToHex = (r: any, g: any, b: any): string => {
- let reg = /^\d{1,3}$/
- if (!reg.test(r) || !reg.test(g) || !reg.test(b)) {
- ElMessage.warning('输入错误的rgb颜色值')
- return ''
- }
- let hexs = [r.toString(16), g.toString(16), b.toString(16)]
- for (let i = 0; i < 3; i++) if (hexs[i].length == 1) hexs[i] = `0${hexs[i]}`
- return `#${hexs.join('')}`
- }
- // color 颜色值字符串 | level 变浅的程度,限0-1之间
- const getDarkColor = (color: string, level: number): string => {
- let reg = /^\#?[0-9A-Fa-f]{6}$/
- if (!reg.test(color)) {
- ElMessage.warning('输入错误的hex颜色值')
- return ''
- }
- let rgb = useTheme().hexToRgb(color)
- for (let i = 0; i < 3; i++) rgb[i] = Math.floor(rgb[i] * (1 - level))
- return useTheme().rgbToHex(rgb[0], rgb[1], rgb[2])
- }
- // color 颜色值字符串 | level 加深的程度,限0-1之间
- const getLightColor = (color: string, level: number): string => {
- let reg = /^\#?[0-9A-Fa-f]{6}$/
- if (!reg.test(color)) {
- ElMessage.warning('输入错误的hex颜色值')
- return ''
- }
- let rgb = useTheme().hexToRgb(color)
- for (let i = 0; i < 3; i++) rgb[i] = Math.floor((255 - rgb[i]) * level + rgb[i])
- return useTheme().rgbToHex(rgb[0], rgb[1], rgb[2])
- }
-
- /**
- * 切换主题颜色
- */
- const changeThemeColor =(color: string)=> {
- document.documentElement.style.setProperty("--el-color-primary", color);
- document.documentElement.style.setProperty("--el-color-primary-dark-2", `${getDarkColor(color, 0.1)}`);
- for (let i = 1; i <= 9; i++) {
- document.documentElement.style.setProperty(`--el-color-primary-light-${i}`, `${getLightColor(color, i / 10)}`);
- }
- }
-
-
- return {
- hexToRgb,
- rgbToHex,
- getDarkColor,
- getLightColor,
- changeThemeColor
- }
- }
在App.vue中,加载后设置主题色,具体如下:
这样,主题色就更改过来了,但是有个问题,页面会从elementplus的默认蓝色变成我设置的色,不在乎的过。若在乎,请自己找其它方案。