gpt4 book ai didi

javascript - 将数组十六进制颜色转换为数组 RGB 颜色

转载 作者:行者123 更新时间:2023-11-28 13:29:54 25 4
gpt4 key购买 nike

我有一个十六进制颜色数组,如下所示:

var hexColors = [
"#ffffff",
"#ffffff",
"#ffffff",
"#f3f3f3",
"#f3f3f3",
"#f3f3f3"];

我想把它变成这样:

var rgbColors = new Array(
[62,35,255],
[60,255,60],
[255,35,98],
[45,175,230],
[255,0,255],
[255,128,0]);

使用此功能:

 function hexToRgb(hex) {
var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
hex = hex.replace(shorthandRegex, function(m, r, g, b) {
return r + r + g + g + b + b;
});
var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result ? {
r: parseInt(result[1], 16),
g: parseInt(result[2], 16),
b: parseInt(result[3], 16)
} : null;
}

我该怎么办?谢谢!

最佳答案

您使这一点变得过于复杂:无需使用正则表达式运行目标字符串两次。在第一次迭代时提取所有信息就足够了。像这样:

function hexToRgb(hex) {
var res = hex.match(/[a-f0-9]{2}/gi);
return res && res.length === 3
? res.map(function(v) { return parseInt(v, 16) })
: null;
}

该函数已准备好在另一个 .map 中使用,给出您想要的结果。

var hexColors = [
"#ffffff",
"#ffffff",
"#ffffff",
"#f3f3f3",
"#f3f3f3",
"#f3f3f3"
];
var rgbColors = hexColors.map(hexToRgb);

Demo

关于javascript - 将数组十六进制颜色转换为数组 RGB 颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25831276/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com