16进制颜色值转RGB颜色以及添加透明度

let color2RGB = (hexColor, opacity) => {
    // 16进制颜色值的正则
    let reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
    let color = hexColor.toLowerCase();
    if (reg.test(color)) {
        // 如果只有三位的值,需变成六位,如:#fff => #ffffff
        if (color.length === 4) {
            let colorNew = "#";
            for (let i = 1; i < 4; i += 1) {
                colorNew += color.slice(i, i + 1).concat(color.slice(i, i + 1));
            }
            color = colorNew;
        }
        // 处理六位的颜色值,转为RGB
        const colorArr = [];
        for (let i = 1; i <= 6; i += 2) {
            colorArr.push(parseInt("0x" + color.slice(i, i + 2)));
        }
        return `rgba(${colorArr.join(",")},${opacity || 1})`
    } else if (/^(rgb)/i.test(color)) {
        // 如果只是rgba修改透明度
        let arr = color.replace(/(?:\(|\)|rgba|rgb)*/gi, "").split(",")
        let colorArr = arr.slice(0, 3)
        let oldOpacity = arr.slice(3)[0] || 1
        return `rgba(${colorArr.join(",")},${['', undefined, null].includes(opacity)? oldOpacity: opacity})`
    } else {
        return color;
    }
};

//调用转换
 color2RGB(十六进制颜色, 0.1);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值