[点晴永久免费OA]JS将十六进制颜色转rgb以及加深减淡颜色值
当前位置:点晴教程→点晴OA办公管理信息系统
→『 经验分享&问题答疑 』
十六进制转换为十进制相对容易些,核心代码如下示例:parseInt("0xFF"),其结果就是255,”0x”就表明当前是16进制,由于parseInt后面无参数,默认就是转换为10进制了。 function colorRgba(str,n){
//十六进制颜色值的正则表达式
var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
var sColor = str.toLowerCase();
n= n||1;
//十六进制颜色转换为RGB格式
if(sColor && reg.test(sColor)){
let sColorChange=getRgbNum(sColor);
return "rgba(" + sColorChange.join(",") + ","+n+")";
}else{
return sColor;
}}function getRgbNum(sColor){
if(sColor.length === 4){
var sColorNew = "#";
for(var i=1; i<4; i+=1){ //补全颜色值 例如:#eee,#fff等
sColorNew += sColor.slice(i,i+1).concat(sColor.slice(i,i+1));
}
sColor = sColorNew;
}
//处理六位颜色值
var sColorChange = [];
for(var i=1; i<7; i+=2){
//核心代码,通过parseInt将十六进制转为十进制,parseInt只有一个参数时是默认转为十进制的,第二个参数则是指定转为对应进制
sColorChange.push(parseInt("0x"+sColor.slice(i,i+2)));
}
return sColorChange;}1234567891011121314151617181920212223242526272829
function LightDarkenColor(color, num) {
let colorArr = getRgbNum(color);
let sColorChange = [];
for(var i=0;i<colorArr.length;i++){
let val = colorArr[i]+num;
if(val<0){
val = 0;
}
if(val>255){
val=255;
}
sColorChange.push(val)
}
return "rgba(" + sColorChange.join(",") + ",1)";}123456789101112131415
该文章在 2023/4/12 9:41:00 编辑过 |
关键字查询
相关文章
正在查询... |