JQUERY1.6 使用方法四 檢測(cè)瀏覽器
下面分別是各個(gè)瀏覽器的navigator.userAgent
//Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN) AppleWebKit/533.21.1 (KHTML, like Gecko) Version/5.0.5 Safari/533.21.1 --safari
//Mozilla/5.0 (Windows NT 5.1) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/13.0.782.220 Safari/535.1 --chrome
//Opera/9.80 (Windows NT 5.1; U; Edition Next; zh-cn) Presto/2.8.158 Version/11.50 --opera
//Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; .NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; InfoPath.1; .NET4.0C; .NET4.0E; InfoPath.2) ---ie
//Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.2.24) Gecko/20111103 Firefox/3.6.24 --firefox
//用于匹配響應(yīng)瀏覽器表示的正則
rwebkit = /(webkit)[ \/]([\w.]+)/,//webkit
ropera = /(opera)(?:.*version)?[ \/]([\w.]+)/,//opera
rmsie = /(msie) ([\w.]+)/,//ie
rmozilla = /(mozilla)(?:.*? rv:([\w.]+))?/,//mozilla
通過(guò)userAgent,我們可以看到chrome可以通過(guò)以下方式匹配到,但是因?yàn)楹蛃afari一樣,都帶有“safari”,我們可以把它放在rwebkit.前進(jìn)行匹配
rchrome=/(Chrome)[ \/]([\w.]+)/
同樣firefox也可以這么做,把它放在rmozilla前面進(jìn)行判斷
rfirefox=/(Firefox)[ \/]([\w.]+)/
uaMatch: function( ua ) {//主要是獲得的瀏覽器的類型和版本
ua = ua.toLowerCase();//參數(shù)為navigator.userAgent。轉(zhuǎn)換成小寫,當(dāng)然也可以在正則匹配里聲明不區(qū)分大小寫(如 /(webkit)[ \/]([\w.]+)/i)
var match = rwebkit.exec( ua ) ||
ropera.exec( ua ) ||
rmsie.exec( ua ) ||
ua.indexOf("compatible") < 0 && rmozilla.exec( ua ) ||
[];//由于使用exec進(jìn)行匹配,返回的結(jié)果是一個(gè)整體匹配和響應(yīng)的子匹配,例如/(Chrome)[ \/]([\w.]+)/,match會(huì)返回Chrome/13.0.782.220,match[1]得到chrome,match[2]得到13.0.782.220;
return { browser: match[1] || "", version: match[2] || "0" };
}
//uaMatch是jQuery里的一個(gè)方法,在這邊開始調(diào)用并保存瀏覽器型號(hào)browser和版本version
browserMatch = jQuery.uaMatch( userAgent );//調(diào)用uaMatch,并返回對(duì)象return { browser: match[1] || "", version: match[2] || "0" };
if ( browserMatch.browser ) {
jQuery.browser[ browserMatch.browser ] = true;//chrome\safari\opera\msie\mozilla ,比如我們要在opera瀏覽器下執(zhí)行特定操作的時(shí)候,可以通過(guò)$.browser.opera來(lái)判斷是不是opera瀏覽器(true,false)
jQuery.browser.version = browserMatch.version;//瀏覽器版本
}
if ( jQuery.browser.webkit ) {
jQuery.browser.safari = true;//因?yàn)閟afari是使用AppleWebKit引擎,由于和chrome都有safari,所以在做另外處理
}
相關(guān)文章
jQuery實(shí)現(xiàn)表單input中提示文字value隨鼠標(biāo)焦點(diǎn)移進(jìn)移出而顯示或隱藏的代碼
表單input中提示文字value隨鼠標(biāo)焦點(diǎn)移進(jìn)移出而顯示或隱藏的jQuery代碼2010-03-03基于jQuery實(shí)現(xiàn)選項(xiàng)卡效果
這篇文章主要為大家詳細(xì)介紹了基于jQuery實(shí)現(xiàn)選項(xiàng)卡效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01基于jQuery的動(dòng)態(tài)增刪改查表格信息,可左鍵/右鍵提示(原創(chuàng)自Zjmainstay)
jQuery動(dòng)態(tài)增刪改查表格信息,可左鍵/右鍵提示的實(shí)現(xiàn)代碼分享,需要的朋友可以參考下2012-07-07jQuery+PHP星級(jí)評(píng)分實(shí)現(xiàn)方法
很多網(wǎng)站都應(yīng)用了星級(jí)評(píng)分效果,讓用戶可以對(duì)正在瀏覽的文章、電影、資源等進(jìn)行評(píng)分,讓網(wǎng)站增添了幾分互動(dòng)效果。本文將講解如何使用jQuery和PHP來(lái)實(shí)現(xiàn)星級(jí)評(píng)分效果。2015-10-10jQuery Animation實(shí)現(xiàn)CSS3動(dòng)畫示例介紹
jQuery Animation的工作原理是通過(guò)將元素的CSS樣式從一個(gè)狀態(tài)改變?yōu)榱硪粋€(gè)狀態(tài),下面以一個(gè)實(shí)例為大家詳細(xì)介紹下具體的實(shí)現(xiàn),感興趣的朋友可以參考下2013-08-08jQuery 常見學(xué)習(xí)網(wǎng)站與參考書
打算學(xué)習(xí)jquery的朋友可以參下如下網(wǎng)上,參考書嗎,可以看下 鋒利的jquery腳本之家提供電子版下載。2009-11-11jQuery-1.9.1源碼分析系列(十一)DOM操作續(xù)之克隆節(jié)點(diǎn)
這篇文章主要介紹了jQuery-1.9.1源碼分析系列(十一)DOM操作續(xù)之克隆節(jié)點(diǎn)的相關(guān)資料,需要的朋友可以參考下2015-12-12jQuery實(shí)現(xiàn)鼠標(biāo)選中文字后彈出提示窗口效果【附demo源碼】
這篇文章主要介紹了jQuery實(shí)現(xiàn)鼠標(biāo)選中文字后彈出提示窗口效果,涉及jQuery事件響應(yīng)及頁(yè)面元素動(dòng)態(tài)操作相關(guān)技巧,非常簡(jiǎn)便實(shí)用,需要的朋友可以參考下2016-09-09jQuery實(shí)現(xiàn)仿百度帖吧頭部固定導(dǎo)航效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)仿百度帖吧頭部固定導(dǎo)航效果,涉及jquery針對(duì)頁(yè)面高度計(jì)算與樣式的動(dòng)態(tài)添加及刪除技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-08-08