十六进制的颜色转变为rgb,设置透明度,通用方法

changeToRgb(color) {
var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
var sColor = color.toLowerCase();
if (sColor && reg.test(sColor)) {
if (sColor.length === 4) {
var sColorNew = "#";
for (var i = 1; i < 4; i += 1) {
sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1));
}
sColor = sColorNew;
}
//处理六位的颜色值
var sColorChange = [];
for (var i = 1; i <= 6; i += 2) {
sColorChange.push(parseInt("0x" + sColor.slice(i, i + 2)));
}
//此处是返回的颜色 如需要透明度,0.3是指透明度30%,直接返回
//"rgba(" + sColorChange.join(",") + ",0.3)"
return "rgba(" + sColorChange.join(",") + ")";
} else {
return sColor;
}
},

如引用本文内容,请标明出处。
原文地址:https://www.cnblogs.com/sky-zky/p/15190562.html