Skip to main content

Background-color hex to JavaScript variable (jQuery)


I'm kind of new to JavaScript and jQuery and now I'm facing a problem:



I need to post some data to PHP and one bit of the data needs to be the background color hex of div X.



jQuery has the css("background-color") function and with it I can get RGB value of the background into a JavaScript variable.



The CSS function seems to return a string like this rgb(0, 70, 255).



I couldn't find any way to get hex of the background-color (even though it's set as hex in CSS).



So it seems like I need to convert it. I found a function for converting RGB to hex, but it needs to be called with three different variables, r, g and b. So I would need to parse the string rgb(x,xx,xxx) into var r=x; var g=xx; var b=xxx; somehow.



I tried to google parsing strings with JavaScript, but I didn't really understand the regular expressions thing.



Is there a way to get the background-color of div as hex, or can the string be converted into 3 different variables?


Source: Tips4allCCNA FINAL EXAM

Comments

  1. try this out:

    var rgbString = "rgb(0, 70, 255)"; // get this in whatever way.

    var parts = rgbString.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
    // parts now should be ["rgb(0, 70, 255", "0", "70", "255"]

    delete (parts[0]);
    for (var i = 1; i <= 3; ++i) {
    parts[i] = parseInt(parts[i]).toString(16);
    if (parts[i].length == 1) parts[i] = '0' + parts[i];
    }
    var hexString ='#'+parts.join('').toUpperCase(); // "#0070FF"


    In response to the question in the comments below:


    I'm trying to modify the regex to handle both rgb and rgba depending which one I get. Any hints? Thanks.


    I'm not exactly sure if it makes sense in the context of this question (since you can't represent an rgba color in hex), but I guess there could be other uses. Anyway, you could change the regex to be like this:

    /^rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*(0\.\d+))?\)$/


    Example output:

    var d = document.createElement('div');
    d.style.backgroundColor = 'rgba( 255, 60, 50, 0)';

    /^rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*(1|0\.\d+))?\)$/.exec(d.style.backgroundColor);

    // ["rgba(255, 60, 50, 0.33)", "255", "60", "50", "0.33"]

    ReplyDelete
  2. You can set a CSS color using rgb also, such as this:

    background-color: rgb(0, 70, 255);


    It is valid CSS, don't worry.



    Edit: See nickf answer for a nice way to convert it if you absolutely need to.

    ReplyDelete
  3. I found another function awhile back (by R0bb13). It doesn't have the regex, so I had to borrow it from nickf to make it work properly. I'm only posting it because it's an interesting method that doesn't use an if statement or a loop to give you a result. Also this script returns the hex value with a # (It was needed by the Farbtastic plugin I was using at the time)

    //Function to convert hex format to a rgb color
    function rgb2hex(rgb) {
    var hexDigits = ["0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"];
    rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
    function hex(x) {
    return isNaN(x) ? "00" : hexDigits[(x - x % 16) / 16] + hexDigits[x % 16];
    }
    return "#" + hex(rgb[1]) + hex(rgb[2]) + hex(rgb[3]);
    }

    // call the function: rgb( "rgb(0, 70, 255)" );
    // returns: #0046ff


    Note: The hex result from nickf's script should be 0046ff and not 0070ff, but no big deal :P

    Update, another better alternative method:

    function rgb2hex(rgb) {
    rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
    function hex(x) {
    return ("0" + parseInt(x).toString(16)).slice(-2);
    }
    return "#" + hex(rgb[1]) + hex(rgb[2]) + hex(rgb[3]);
    }

    ReplyDelete
  4. If you have jQuery available, this is the super-compact version that I just came up with.


    var RGBtoHEX = function(color) {
    return "#"+$.map(color.match(/\b(\d+)\b/g),function(digit){
    return ('0' + parseInt(digit).toString(16)).slice(-2)
    }).join('');
    };

    ReplyDelete
  5. With JQuery..

    var cssColorToHex = function(colorStr){
    var hex = '#';
    $.each(colorStr.substring(4).split(','), function(i, str){
    var h = ($.trim(str.replace(')',''))*1).toString(16);
    hex += (h.length == 1) ? "0" + h : h;
    });
    return hex;
    };

    ReplyDelete
  6. These solutions will fail in Chrome, as it returns an rgba(x,x,x,x) for background-color.

    EDIT: This is not necessarily true. Chrome will still set backgrounds using rgb(), depending on what you are doing. Most likely as long as there is no alpha channel applied, Chrome will respond with rgb instead of rgba.

    ReplyDelete
  7. http://www.phpied.com/rgb-color-parser-in-javascript/

    A JavaScript class that accepts a string and tries to figure out a valid color out of it. Some accepted inputs are for example:

    * rgb(0, 23, 255)
    * #336699
    * ffee66
    * fb0
    * red
    * darkblue
    * cadet blue

    ReplyDelete
  8. Here you go, this will allow you to use $(selector).getHexBackgroundColor() to return the hex value easily :

    $.fn.getHexBackgroundColor = function() {
    var rgb = $(this).css('background-color');
    rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
    function hex(x) {return ("0" + parseInt(x).toString(16)).slice(-2);}
    return "#" + hex(rgb[1]) + hex(rgb[2]) + hex(rgb[3]);
    }

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.