这篇文章主要介绍了javascript实现十六进制颜色值(HEX)和RGB格式之间的转换,使用正则的方法实现RGB颜色转换为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<aColor.length; i++){
  var hex = Number(aColor).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+aNum);
  }
  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; 
  }};

使用颜色转换方法:

ar sRgb = "RGB(23, 245, 56)" , sHex = "#34538b";
var sHexColor = sRgb.colorHex();
var sRgbColor = sHex.colorRgb();

最新资讯
欧洲专利局研究:三星电池专利申请量为全球第一

欧洲专利局研究:三星电

欧洲专利局(EPO)与国际能源署(IEA)22日发布一项共同研究结
滴滴橙心优选与中粮福临门达成合作 涉及商品供应等方面

滴滴橙心优选与中粮福

滴滴旗下社区电商平台橙心优选与中粮福临门食品营销有
Facebook内容监管委员会大选前运作 可推翻扎克伯格决定

Facebook内容监管委员

该监督委员会被一些人士称为Facebook的“最高法(tian)院(ping)”,有
特斯拉新电池计划发布 对谁的威胁最大?

特斯拉新电池计划发布

虽然现在特斯拉的电池计划并未成为现实,但随着特斯拉从
拼多多低市价1000元卖茅台,茅台称没供货

拼多多低市价1000元卖

拼多多上第三方卖家销售的53度飞天茅台价格远低于市场
美团配送魏巍:开放平台业务规模已增长175%

美团配送魏巍:开放平台

美团配送总经理魏巍透露,自去年宣布对外开放即时配送能
最新文章
详解Vue的ref特性的使用

详解Vue的ref特性的使

这篇文章主要介绍了详解Vue的ref特性的使用,文中通过
vue学习笔记之slot插槽基本用法实例分析

vue学习笔记之slot插

这篇文章主要介绍了vue学习笔记之slot插槽基本用法,结
vue跳转方式(打开新页面)及传参操作示例

vue跳转方式(打开新页

这篇文章主要介绍了vue跳转方式(打开新页面)及传参操作,
vue学习笔记之过滤器的基本使用方法实例分析

vue学习笔记之过滤器

这篇文章主要介绍了vue学习笔记之过滤器的基本使用方
js获取本日、本周、本月的时间代码

js获取本日、本周、本

本篇文章给大家分享的内容是利用js如何获取本日、本周
node crawler如何添加promise支持

node crawler如何添加

这篇文章主要介绍了node crawler如何添加promise支持,