【16進制轉換為RGB 】
16進制一般有3位或者6位,如果為3位的話,需要補齊為6位
set16ToRgb(str){ var reg = /^#([0-9A-Fa-f]{3}|[0-9A-Fa-f]{6})$/ if(!reg.test(str)){return;} let newStr = (str.toLowerCase()).replace(/\#/g,'') let len = newStr.length; if(len == 3){ let t = '' for(var i=0;i<len;i++){ t += newStr.slice(i,i+1).concat(newStr.slice(i,i+1)) } newStr = t } let arr = []; //將字符串分隔,兩個兩個的分隔 for(var i =0;i<6;i=i+2){ let s = newStr.slice(i,i+2) arr.push(parseInt("0x" + s)) } return 'rgb(' + arr.join(",") + ')'; }
調用方法如: set16ToRgb("#3ef")
【RGB轉換為16進制 】
//將rgb的轉換為16進制 setRgbTo16(str){ let reg = /^(rgb|RGB)/; if(!reg.test(str)){return;} var arr = str.slice(4, str.length-1).split(",") let color = '#'; for(var i=0;i<arr.length;i++){ var t = Number(arr[i]).toString(16) if(t == "0"){ //如果為“0”的話,需要補0操作,否則只有5位數 t = t + "0" } color += t; } return color; }
調用方法如:setRgbTo16("rgb(255,0,255)");