일상적인 개발에서는 다양한 형식의 색상 범위 값 간의 변환이 자주 사용됩니다. 해결 방법은 다음과 같습니다.
//16진수 색상 값에 대한 정규식
var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
/*RGB 색상을 16진수로 변환*/
String.prototype.colorHex = function(){
var that = this;
If(/^(rgb|RGB)/.test(that)){
var aColor = that.replace(/(?:(|)|rgb|RGB)*/g,"").split(",");
var strHex = "#";
for(var i=0; i
var hex = Number(aColor).toString(16);
if(hex === "0"){
16진수 = 16진수
}
strHex = 16진수;
}
If(strHex.length !== 7){
strHex = that;
}
strHex를 반환합니다.
}else if(reg.test(that)){
var aNum = that.replace(/#/,"").split("");
If(aNum.length === 6){
반품하세요.
}else if(aNum.length === 3){
var numHex = "#";
for(var i=0; i
numHex = (aNum aNum);
}
numHex를 반환합니다.
}
}그밖에{
반품하세요.
}};
/*16진수 색상을 RGB 형식으로 변환*/
String.prototype.colorRgb = 함수(){
var sColor = this.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;
}
//6자리 색상 값 처리
var sColorChange = [];
for(var i=1; i<7; i =2){
sColorChange.push(parseInt("0x" sColor.slice(i,i 2)));
}
return "RGB(" sColorChange.join(",") ")";
}그밖에{
sColor 반환;
}};
색상 변환 방법 사용: