>웹 프론트엔드 >JS 튜토리얼 >Javascript는 16진수 색상 값(HEX)과 RGB 형식 간의 상호 변환을 구현합니다_javascript 기술

Javascript는 16진수 색상 값(HEX)과 RGB 형식 간의 상호 변환을 구현합니다_javascript 기술

WBOY
WBOY원래의
2016-05-16 16:43:411436검색

일상적인 개발에서는 다양한 형식의 색상 범위 값 간의 변환이 자주 사용됩니다. 해결 방법은 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

//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 반환;                                                 }};


색상 변환 방법 사용:



코드 복사

코드는 다음과 같습니다.

ar sRgb = "RGB(23, 245, 56)" , sHex = "#34538b";
var sHexColor = sRgb.colorHex();
var sRgbColor = sHex.colorRgb();
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.