/**
 * kevin 2021.1.4
 * 将rgb表示方式转换为hex表示方式
 * @param {string} rgbColor 传过来的hex格式的颜色
 * @returns {string | null}
 */
export function colorHex(rgbColor) {
  var _this = rgbColor
  var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
  if (/^(rgb|RGB)/.test(_this)) {
    var aColor = _this.replace(/(?:\(|\)|rgb|RGB)*/g, '').split(',')
    var strHex = '#'
    for (var i = 0; i < aColor.length; i++) {
      var hex = Number(aColor[i]).toString(16)
      hex = hex < 10 ? 0 + '' + hex : hex// 保证每个rgb的值为2位
      if (hex === '0') {
        hex += hex
      }
      strHex += hex
    }
    if (strHex.length !== 7) {
      strHex = _this
    }
    return strHex
  } else if (reg.test(_this)) {
    var aNum = _this.replace(/#/, '').split('')
    if (aNum.length === 6) {
      return _this
    } else if (aNum.length === 3) {
      var numHex = '#'
      for (var j = 0; j < aNum.length; j += 1) {
        numHex += (aNum[j] + aNum[j])
      }
      return numHex
    }
  } else {
    return _this
  }
}
 
/**
 * kevin 2021.1.4
 * 将hex表示方式转换为rgb表示方式(这里返回rgb数组组合)
 * @param {string} hexColor 传过来的hex格式的颜色
 * @returns {string | null}
 */
export function colorRgb(hexColor) {
  var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
  var sColor = hexColor.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 j = 1; j < 7; j += 2) {
      sColorChange.push(parseInt('0x' + sColor.slice(j, j + 2)))
    }
    return sColorChange
  } else {
    return sColor
  }
}

最新文章

  1. JS/CSS收藏
  2. 解决bind错误 bind: Address already in use
  3. java Util
  4. PHP 魔术引号
  5. Remainder
  6. JDK环境变量安装正确还报错的情况解决方案
  7. android 开发 获取各种intent (图片、apk文件、excel、pdf等文件)
  8. TS流格式(转)
  9. linux 学习笔记 GNU工具链简介
  10. npm:Node.js的软件包管理器
  11. 强势围观,CSDN代码引用bug
  12. POJ 2942 Knights of the Round Table - from lanshui_Yang
  13. ASP.NET MVC中错误处理方式
  14. Apache 2.4.27 局域网访问提示 You don&#39;t have permission to access / on this server
  15. springboot 读取 resource文件
  16. 数据库 Mysql 使用,优化,索引
  17. CF1114E Arithmetic Progression
  18. JVM Scan
  19. alpha阶段 代码结构及技术难点简介
  20. HiveThrift

热门文章

  1. House_of_orange 学习小结
  2. 一周内被程序员疯转3.2W次,最终被大厂封杀的《字节跳动Android面试手册》!
  3. Ubuntu上安装gevent
  4. MongoDB-01-基础
  5. SpringBoot开发二十一-发送私信
  6. NOIP 模拟 $36\; \rm Dove 打扑克$
  7. 题解 P6271 [湖北省队互测2014]一个人的数论
  8. 百度地图开发-引入地图SDK并配置 02
  9. 【MyBatis系列5】MyBatis4大核心对象SqlSessionFactoryBuiler,SqlSessionFactory,SqlSession,Mapper
  10. 【mysql】截取查询分析