zoukankan      html  css  js  c++  java
  • javascript实现 color颜色格式转换【 rgb和十六进制的转换】

       以原型的方式,给string字符串类型添加方法,用于实现颜色值格式的转换;不习惯使用原型方法的,只要借鉴实现方法就好!

    代码如下:

    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<aColor.length; i++){
                   var hex = Number(aColor[i]).toString(16);
                   if(hex === "0"){
                        hex += hex;    
                   }
                   strHex += hex;
              }
              if(strHex.length !== 7){
                   strHex = that;    
              }
              return strHex;
         }else if(reg.test(that)){
              var aNum = that.replace(/#/,"").split("");
              if(aNum.length === 6){
                   return that;    
              }else if(aNum.length === 3){
                   var numHex = "#";
                   for(var i=0; i<aNum.length; i+=1){
                        numHex += (aNum[i]+aNum[i]);
                   }
                   return numHex;
              }
         }else{
              return that;    
         }
    };
    
    //-------------------------------------------------
    
    /*16进制颜色转为RGB格式*/
    String.prototype.colorRgb = function(){
         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;
              }
              //处理六位的颜色值
              var sColorChange = [];
              for(var i=1; i<7; i+=2){
                   sColorChange.push(parseInt("0x"+sColor.slice(i,i+2)));    
              }
              return "RGB(" + sColorChange.join(",") + ")";
         }else{
              return sColor;    
         }
    };
    function (){
         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;
              }
              //处理六位的颜色值
              var sColorChange = [];
              for(var i=1; i<7; i+=2){
                   sColorChange.push(parseInt("0x"+sColor.slice(i,i+2)));    
              }
              return "RGB(" + sColorChange.join(",") + ")";
         }else{
              return sColor;    
         }
    }

     

    使用方法如下:

    "rgb(255,255,255)".colorHex();
    //输出: "#ffffff"
    
    "#ffffff".colorRgb();
    //输出:"RGB(255,255,255)"

     

      


    ------------------------------------------------

      博主经营一家发饰淘宝店,都是纯手工制作哦,开业冲钻,只为信誉!需要的亲们可以光顾一下!谢谢大家的支持!
    店名:
      小鱼尼莫手工饰品店
    经营:
      发饰、头花、发夹、耳环等(手工制作)
    网店:
      http://shop117066935.taobao.com/

      ---------------------------------------------------------------------

     

    转载请注明出处:http://www.cnblogs.com/qiongmiaoer/p/4566083.html

  • 相关阅读:
    用js写留言信息的判断非空条件
    tp3.2中怎么访问分类及子分类下面的文章
    关于PHP中的 serialize () 和 unserialize () 的使用(即关于PHP中的值与已存储的表示的相互转换)
    iOS 8 Auto Layout界面自动布局系列2-使用Xcode的Interface Builder添加布局约束
    iOS深入学习(Block全面分析)
    面试4
    Android
    android适配不同分辨率的手机
    android分辨率适配
    Android屏幕适配全攻略(最权威的官方适配指导)
  • 原文地址:https://www.cnblogs.com/qiongmiaoer/p/4566083.html
Copyright © 2011-2022 走看看