• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

jQuery颜色值转换为十六进制形式核心代码

jQuery 程序员 2年前 (2019-03-05) 224次浏览 已收录 0个评论

谷歌、火狐和IE8以上浏览器中,获取的颜色值是RGB形式,例如rgb(255,255,255),感觉非常不适,在实际编码中不方便使用。

这个时候需要进行转换,下面就提供一段相关转换代码。

以上代码实现了我们的要求,可以将RGB格式的颜色值转换为十六进制形式,下面就简单介绍一下实现过程:

一.实现原理:

当点击按钮的会触发click事件,进而执行click事件处理函数,此处理函数能够将转换后的颜色值写入div中去,其中的核心函数就是getHexBackgroundColor(),此函数首先会判断浏览器是否是IE9之下,如果是则直接返回颜色值,不进行转换,因为在IE9以下浏览器获取的颜色值就是16进制的,如果是IE8以上浏览器或者谷歌火狐,则需要进行转换,关于转换细节这里就不多介绍了,可以参考你代码注释。

二.代码注释:

(1).$.fn.getHexBackgroundColor=function(id,property){},声明一个函数,此函数可以可以进行颜色值转换,此函数具有两个参数,第一个参数是元素的id属性值,第二个是属性。

(2).var rgb=$(id).css(property),获取颜色值,这个时候rgb也许是16进制也许是RGB格式的。

(3).if($.browser.msie&&$.browser.version>8||$.browser.mozilla||$.browser.webkit),判断浏览器是否是IE8以上或者是火狐或者谷歌浏览器。

(4).rgb=rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/),这个要对正则表达式有所了解,通过match()函数可以将颜色值字符串生成一个数组,这个数组中有4个元素,以rgb(102, 0, 255)作为例子,第一个元素是整个颜色值字符串rgb(102, 0, 255),第二个数组元素是102,第三个是0,第四个是255。

(5).function hex(x){},声明一个函数,此函数可以用就是进行颜色值转换,具有一个参数,传递的是rgb数组的某一项。

(6).return (“0″+parseInt(x).toString(16)).slice(-2),可以将传入数值转换为16进制,注意前面是添加了一个0,最好使用slice函数截取最后两个字符,并返回截取的这两个字符。

(7).rgb=”#”+hex(rgb[1])+hex(rgb[2])+hex(rgb[3]),将值组合起来。

(8).return rgb,返回rgb这个值。

(9).$(document).ready(function(){}),当文档结构完全加载完毕再去执行函数中的代码。

(10).$(“#bt”).click(function(){}),为按钮注册click事件处理桉树。

(12).$(“#thediv”).text($.fn.getHexBackgroundColor(“#Id”,”color”)) ,将转换后的颜色值写入div。


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址