使用JSColor,用户选择颜色后,如何获取“十六进制”?
$("input#colorpicker").css('background-color') => this returns background-color: rgb(107, 132, 255);
但不是十六进制。
最佳答案
我假设 jQuery.css 返回设置的值。 尝试使用以下函数将 RGB 转换为 HEX:
function colorToHex(color) {
if (color.substr(0, 1) === '#') {
return color;
}
var digits = /(.*?)rgb\((\d+), (\d+), (\d+)\)/.exec(color);
var red = parseInt(digits[2]);
var green = parseInt(digits[3]);
var blue = parseInt(digits[4]);
var rgb = blue | (green << 8) | (red << 16);
return digits[1] + '#' + rgb.toString(16);
};
colorToHex('rgb(120, 120, 240)')
关于javascript - 在 JSColor 中,如何获取颜色的十六进制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8868404/