麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jquery實現(xiàn)將獲取的顏色值轉(zhuǎn)換為十六進(jìn)制形式的方法

2019-11-20 13:39:10
字體:
供稿:網(wǎng)友

本文實例講述了jquery實現(xiàn)將獲取的顏色值轉(zhuǎn)換為十六進(jìn)制形式的方法。分享給大家供大家參考。具體分析如下:

大家或許已經(jīng)注意到了,在谷歌、火狐和IE8以上瀏覽器中,獲取的顏色值是RGB形式,例如rgb(255,255,0),感覺非常不適應(yīng),或者在實際編碼中不方便使用,這個時候就需要進(jìn)行轉(zhuǎn)換,下面就提供一段相關(guān)轉(zhuǎn)換代碼。

具體代碼如下:

復(fù)制代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.companysz.com/" />
<title>顏色格式轉(zhuǎn)換-武林網(wǎng)</title> 
<style type="text/css">
#thediv
{
  width:200px;
  height:100px;
  background-color:#CCC;
  line-height:100px;
  text-align:center;
  color:#60F;
}
</style>
<script type="text/javascript" src="jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript">
$.fn.getHexBackgroundColor=function(id,property)

  var rgb=$(id).css(property); 
  if($.browser.msie&&$.browser.version>8||$.browser.mozilla||$.browser.webkit)
  { 
    rgb=rgb.match(/^rgb/((/d+),/s*(/d+),/s*(/d+)/)$/); 
    function hex(x) 
    { 
      return ("0"+parseInt(x).toString(16)).slice(-2); 
    } 
    rgb="#"+hex(rgb[1])+hex(rgb[2])+hex(rgb[3]); 
  } 
  return rgb; 

$(document).ready(function(){ 
  $("#bt").click(function(){
    $("#thediv").text($.fn.getHexBackgroundColor("#thediv","color")) 
  })
})
</script> 
</head>
<body>
<div id="thediv">武林網(wǎng)</div>
<input type="button" value="點擊查看效果" id="bt" />
</body>
</html>

注意:運行編輯器之后,再按F5刷新網(wǎng)頁即可查看演示。

以上代碼實現(xiàn)了我們的要求,可以將RGB格式的顏色值轉(zhuǎn)換為十六進(jìn)制形式,下面就簡單介紹一下實現(xiàn)過程:

一.實現(xiàn)原理:

當(dāng)點擊按鈕的會觸發(fā)click事件,進(jìn)而執(zhí)行click事件處理函數(shù),此處理函數(shù)能夠?qū)⑥D(zhuǎn)換后的顏色值寫入div中去,其中的核心函數(shù)就是getHexBackgroundColor(),此函數(shù)首先會判斷瀏覽器是否是IE9之下,如果是則直接返回顏色值,不進(jìn)行轉(zhuǎn)換,因為在IE9以下瀏覽器獲取的顏色值就是16進(jìn)制的,如果是IE8以上瀏覽器或者谷歌火狐,則需要進(jìn)行轉(zhuǎn)換,關(guān)于轉(zhuǎn)換細(xì)節(jié)這里就不多介紹了,可以參考你代碼注釋。

二.代碼注釋:

1.$.fn.getHexBackgroundColor=function(id,property){},聲明一個函數(shù),此函數(shù)可以可以進(jìn)行顏色值轉(zhuǎn)換,此函數(shù)具有兩個參數(shù),第一個參數(shù)是元素的id屬性值,第二個是屬性。

2.var rgb=$(id).css(property),獲取顏色值,這個時候rgb也許是16進(jìn)制也許是RGB格式的。

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

4.rgb=rgb.match(/^rgb/((/d+),/s*(/d+),/s*(/d+)/)$/),這個要對正則表達(dá)式有所了解,通過match()函數(shù)可以將顏色值字符串生成一個數(shù)組,這個數(shù)組中有4個元素,以rgb(102, 0, 255)作為例子,第一個元素是整個顏色值字符串rgb(102, 0, 255),第二個數(shù)組元素是102,第三個是0,第四個是255。

5.function hex(x){},聲明一個函數(shù),此函數(shù)可以用就是進(jìn)行顏色值轉(zhuǎn)換,具有一個參數(shù),傳遞的是rgb數(shù)組的某一項。

6.return ("0"+parseInt(x).toString(16)).slice(-2),可以將傳入數(shù)值轉(zhuǎn)換為16進(jìn)制,注意前面是添加了一個0,最好使用slice函數(shù)截取最后兩個字符,并返回截取的這兩個字符。

7.rgb="#"+hex(rgb[1])+hex(rgb[2])+hex(rgb[3]),將值組合起來。

8.return rgb,返回rgb這個值。

9.$(document).ready(function(){}),當(dāng)文檔結(jié)構(gòu)完全加載完畢再去執(zhí)行函數(shù)中的代碼。

10.$("#bt").click(function(){}),為按鈕注冊click事件處理桉樹。

11.$("#thediv").text($.fn.getHexBackgroundColor("#thediv","color")) ,將轉(zhuǎn)換后的顏色值寫入div。

三.相關(guān)閱讀:

1.瀏覽器版本判斷可以參閱《JavaScript 判斷瀏覽器類型及版本》。
2. parseInt()函數(shù)可以參閱《javascript中parseInt()函數(shù)的定義和用法分析》。
3.toString()函數(shù)可以參閱《javascript中Number對象的toString()方法分析》。
4.slice()函數(shù)可以參閱《javascript中String對象的slice()方法分析》。
5.click事件可以參閱《jQuery中click事件的定義和用法》。
6.text()函數(shù)可以參閱《jQuery的text()方法用法分析》。

希望本文所述對大家的jQuery程序設(shè)計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 99影视在线视频免费观看 | 日本人乱人乱亲乱色视频观看 | 国产精品视频久久久 | 97黄色网| 在线看免费观看av | 精品亚洲va在线va天堂资源站 | 伊人亚洲精品 | 香蕉在线看 | 国产精品久久久久久久久久久久久久久久 | 日韩中字在线 | 久久精品一二三区 | 激情小说激情电影 | 中文字幕在线观看网址 | 黄色av一区二区三区 | 久久久久夜色精品国产老牛91 | 蜜桃视频在线免费播放 | 日韩精品中文字幕在线播放 | 中文字幕www | 国产中出视频 | 欧美一区二区三区不卡免费观看 | 视频一区二区久久 | 国产成人在线看 | 色播视频在线播放 | av免费提供| 久章草在线视频 | 久久欧美亚洲另类专区91大神 | 国产91免费看 | 日韩中文字幕一区二区三区 | 久久久久久久免费精品 | 婷婷亚洲一区二区三区 | 久草在线视频在线 | 国产精品999在线 | 九九热在线免费观看视频 | 毛片大全免费看 | 色婷婷久久久亚洲一区二区三区 | 91精品国产91久久久久久蜜臀 | 国产精品一区在线免费观看 | 本站只有精品 | 久久久青青草 | 视频一区二区久久 | 亚洲第一精品在线 |