js动态设置css主题(Style-setProperty)

hex颜色转RGB


javascript 复制代码
hex2rgb(str = '') {
        str = str.replace("#", "");
        const hxs: any = str.match(/../g);
        for (let index = 0; index < 3; index++) hxs[index] = parseInt(hxs[index], 16);
        return hxs;
    }

RGB转HXS


javascript 复制代码
rgb2hex(r: any, g: any, b: any) {
        const hexs = [r.toString(16), g.toString(16), b.toString(16)];
        for (let index = 0; index < 3; index++) {
            const isHave = hexs[index].length == 1;
            if (isHave) hexs[index] = "0" + hexs[index];
        }
        return "#" + hexs.join("");
    }

颜色加深


javascript 复制代码
getDark(color: any, level: any) {
        const rgb = this.hex2rgb(color);
        for (let index = 0; index < 3; index++) {
            rgb[index] = Math.floor(rgb[index] * (1 - level))
        }
        return this.rgb2hex(rgb[0], rgb[1], rgb[2]);
    }

颜色变淡


javascript 复制代码
getLight(color: any, level: any) {
        const rgb = this.hex2rgb(color);
        for (let index = 0; index < 3; index++) {
            rgb[index] = Math.floor((255 - rgb[index]) * level + rgb[index])
        }
        return this.rgb2hex(rgb[0], rgb[1], rgb[2]);
    }

定义后端返回主题色


定义的参考色,在开发的过程中希望后端人员能遵循

javascript 复制代码
const themeConf={
    primary: '#183ee4',
	success: '#0cce63',
	warn: '#ff4900',
	danger: '#f00c63'
}
javascript 复制代码
getTheme(temeConf) {
    const obj={};
    Object.keys(temeConf).forEach(key => {
	    let color = temeConf[key];
        // 用于按钮点击颜色
	    const dColor = this.getDark(color, 0.2);
	    obj[`--${key}`] = color;
	    obj[`--${key}--active`] = dColor;
	    for (let num = 1; num <= 4; num++) {
	        const val = this.getLightColor(color, num / 10);
	        obj[`--${key}-${num}`] = val;
	    }
    });
    return obj;
}

将组元录入

1、在index.html内添加style标签录入(可录入::root下不挂在到任何标签)

javascript 复制代码
setTheme(temeConf: any) {
        let eStr: string = '';
        Object.keys(temeConf).forEach(key => {
            let color = temeConf[key];
            // 用于按钮点击颜色
            const dColor = this.getDark(color, 0.2);
            eStr += `--${key}:${color};`;
            eStr += `--${key}--active:${dColor};`;
            for (let num = 1; num <= 4; num++) {
                const val = this.getLight(color, num / 10);
                eStr += `--${key}-${num}:${val};`;
            }
        });
        let styleDom = document.getElementById('#sysCssElemnet');
        if (!styleDom) {
            styleDom = document.createElement("style");
            styleDom.id = "#sysCssElemnet";
            document.head.append(styleDom);
        }
        styleDom.innerHTML = `:root{${eStr}}`;
    }

2、将组元录入到html

javascript 复制代码
let html=document.documentElement;
const themeObj=getTheme(themConf);
Object.keys(themeObj).forEach(key=>html.style.setProperty(key,colorObj[key]));

注:如果采用第二种方式录入,建议可直接在getTheme时直接在for循环中setProperty相关组元属性

相关推荐
paterWang1 小时前
基于 Python 和 OpenCV 的酒店客房入侵检测系统设计与实现
开发语言·python·opencv
东方佑1 小时前
使用Python和OpenCV实现图像像素压缩与解压
开发语言·python·opencv
天宇&嘘月2 小时前
web第三次作业
前端·javascript·css
我真不会起名字啊2 小时前
“深入浅出”系列之杂谈篇:(3)Qt5和Qt6该学哪个?
开发语言·qt
laimaxgg2 小时前
Qt常用控件之单选按钮QRadioButton
开发语言·c++·qt·ui·qt5
水瓶丫头站住2 小时前
Qt的QStackedWidget样式设置
开发语言·qt
小王不会写code2 小时前
axios
前端·javascript·axios
发呆的薇薇°3 小时前
vue3 配置@根路径
前端·vue.js
小钊(求职中)3 小时前
Java开发实习面试笔试题(含答案)
java·开发语言·spring boot·spring·面试·tomcat·maven
luckyext3 小时前
HBuilderX中,VUE生成随机数字,vue调用随机数函数
前端·javascript·vue.js·微信小程序·小程序