css rgb转16进制,jquery获取元素颜色css('color')的值返回RGB。如何转十六进制

css代码如下:a, a:link, a:visited { color:#4188FB; }a:active, a:focus, a:hover { color:#FFCC00; }

js代码如下:var link_col = $("a:link").css("color");

alert(link_col);

返回的值:rgb(65, 136, 251)

jquey设置颜色,使用的应该是rgb格式的。用以下这个function,把rgb转成“#xxxx”(HEX )格式。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(''); // "0070ff"

或者用这个functionfunction 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]);

}

可以摘取其中重点语句举一反三

转一个js rgb颜色转16进制格式的代码

今天半个苹果同学要处理getComputedStyle的颜色值,IE下返回的是#FF000这样了 现代浏览器返回的是rgb(255,0,0) 需要做下转换,我正写着代码 他又发我一个url 就是下面这个,是我见过最好的转换代码了 特此记录

原文:http://fayaa.com/code/view/200/

copycode.giffunction zero_fill_hex(num, digits) {  var s = num.toString(16);  while (s.length 

s = "0" + s;  return s;

}function rgb2hex(rgb) {  if (rgb.charAt(0) == '#')    return rgb;

var ds = rgb.split(/\D+/);  var decimal = Number(ds[1]) * 65536 + Number(ds[2]) * 256 + Number(ds[3]);  return "#" + zero_fill_hex(decimal, 6);

}

copycode.gif

补充   位运算版本:function rgbToHex(r, g, b) { return ((r <

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值