2010-06-15 167 views
16

在我的CSS文件:jQuery的css顏色值返回RGB?

a, a:link, a:visited { color:#4188FB; } 
a:active, a:focus, a:hover { color:#FFCC00; } 

我嘗試:

var link_col = $("a:link").css("color"); 
alert(link_col); // returns rgb(65, 136, 251) 

我怎樣才能獲得的十六進制代碼?

***編輯:在這裏找到了答案:
Background-color hex to JavaScript variable

可恥的是我,可能會對搜索發佈前好一點..

+0

http://stackoverflow.com/questions/1740700/jquery-get-hex-value-rather-rgb背景色十六進制JavaScript變量的 – user113716 2010-06-15 20:40:03

+0

可能重複(jQuery的) ](http://stackoverflow.com/questions/638948/background-color-hex-to-javascript-variable-jquery) – zzzzBov 2011-01-19 21:00:12

回答

4

在這裏你去,這將允許您使用$(選擇).getHexBackgroundColor()返回容易的十六進制值:

$.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]); 
} 
+1

在ie8失敗,請參閱http://stackoverflow.com/a/7380712/21460 – 2011-12-12 23:00:17

8

一些adjustes運作

$.fn.getHexBackgroundColor = function() { 
    var rgb = $(this).css('background-color'); 
    if (!rgb) { 
     return '#FFFFFF'; //default color 
    } 
    var hex_rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/); 
    function hex(x) {return ("0" + parseInt(x).toString(16)).slice(-2);} 
    if (hex_rgb) { 
     return "#" + hex(hex_rgb[1]) + hex(hex_rgb[2]) + hex(hex_rgb[3]); 
    } else { 
     return rgb; //ie8 returns background-color in hex format then it will make     compatible, you can improve it checking if format is in hexadecimal 
    } 
} 
0

這是我的要求。簡單而簡潔。

(function($) { 
 
    $.fn.getHexBackgroundColor = function() { 
 
    return (function(rgb) { 
 
     return '#' + (!rgb 
 
     ? 'FFFFFF' 
 
     : rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/) 
 
      .slice(1) 
 
      .map(x => ('0' + parseInt(x).toString(16)).slice(-2)) 
 
      .join('') 
 
      .toUpperCase()); 
 
    })($(this).css('background-color')); 
 
    } 
 
})(jQuery); 
 

 
$(function() { 
 
    $('#color-rgb').text($('.foo').css('background-color')); 
 
    $('#color-hex').text($('.foo').getHexBackgroundColor()); 
 
});
.foo { 
 
    background: #F74; 
 
    width: 100px; 
 
    height: 100px; 
 
} 
 

 
label { font-weight: bold; } 
 
label:after { content: ': '; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div class="foo"></div> 
 
<label>RGB</label><span id="color-rgb">UNDEF</span><br /> 
 
<label>HEX</label><span id="color-hex">UNDEF</span>