[颜色进制转换]js实现rgb和hex的相互转换




原理

  • RGB色彩模式是工业界的一种颜色标准,是通过对红®、绿(G)、蓝(B)三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB即是代表红、绿、蓝三个通道的颜色,这个标准几乎包括了人类视力所能感知的所有颜色,是运用最广的颜色系统之一。

  • 决定颜色的有三种:红,绿,蓝。每种都是0-255。这3个自由组合组成各种颜色。

  • 255换成16进制就是FF,#FFFFFF就是红色255 ,绿色255,蓝色255 ,组成白色

将rgb颜色转成hex

// 将rgb颜色转成hex  输入(24,12,255)
function colorRGB2Hex(r,g,b) {
    
    let hex = "#" + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);
    return hex;
}

rgb色转成hex : colorRGB2Hex(255,255,255);

返回hex值 如#cccccc

image-20201214121946426





将hex颜色转成rgb

// 将hex颜色转成rgb
function hexToRgba(hex, opacity) {
    let RGBA = "rgba(" + parseInt("0x" + hex.slice(1, 3)) + "," + parseInt("0x" + hex.slice(3, 5)) + "," + parseInt( "0x" + hex.slice(5, 7)) + "," + opacity + ")";
    return {
        red: parseInt("0x" + hex.slice(1, 3)),
        green: parseInt("0x" + hex.slice(3, 5)),
        blue: parseInt("0x" + hex.slice(5, 7)),
        rgba: RGBA
    }
}

hex转成rgba: hexToRgba("#cccccc", 1);

第一个参数为hex色值,第二个参数为透明度,返回对象

image-20201214121824134

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值