在JSColor中,我如何获得颜色的十六进制?

时间:2012-01-15 08:21:10

标签: javascript jquery css jscolor

使用JSColor,在用户选择颜色后,如何获得“hex”?

$("input#colorpicker").css('background-color') => this returns background-color: rgb(107, 132, 255);

但不是十六进制。

3 个答案:

答案 0 :(得分:3)

我假设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)')

答案 1 :(得分:1)

实际上这取决于它以rgb或hex返回的浏览器,无论如何看看这个帖子有很好的讨论,并且还有很多解决方案。

Background-color hex to JavaScript variable

How to get hex color value rather than RGB value?

Can I force jQuery.css("backgroundColor") returns on hexadecimal format?

jquery css color value returns RGB?

答案 2 :(得分:0)

有onchange事件:

$("input#colorpicker").change(function() {
    console.log(this.color);
});