带alpha值不透明度的十六进制颜色和rgba互相转换的函数

本文分享了一个实用的函数,用于在十六进制颜色代码和RGBA数组间进行转换,适用于前端开发中颜色处理的需求。文章由一位新手开发者撰写,诚邀读者提出改进建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发中一直要把两种颜色互相转换,所以写了这个函数,我是新手,有不足的地方请指教。

/**十六进制颜色和rgba互相转换
 * @param color 十六进制字符串,rgba数组
 */
function colorConvert(color) {
  let a, b, c, d
  if (color[0] === "#") {
    a = parseInt(color[1] + color[2], 16)
    b = parseInt(color[3] + color[4], 16)
    c = parseInt(color[5] + color[6], 16)
    d = parseInt(color[7] + color[8], 16)
    return [a, b, c, d]
  } else {
    a = color[0].toString(16)
    b = color[1].toString(16)
    c = color[2].toString(16)
    d = color[3].toString(16)
    a = a.length === 2 ? a : '0' + a
    b = b.length === 2 ? b : '0' + b
    c = c.length === 2 ? c : '0' + c
    d = d.length === 2 ? d : '0' + d
    return '#' + a + b + c + d
  }
}

运行结果

十六进制转换rgba格式

十六进制转换rgba格式

rgba格式转换十六进制

rgba格式转换十六进制
由于我不经常用到rgb格式,所以要转换不带alpha值格式的需要修改一下函数。

如有不足请指教哈
云程序员

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值