JavaScript編寫(xiě)檢測(cè)用戶所使用的瀏覽器的代碼示例
能力檢測(cè)
在編寫(xiě)代碼之前先檢測(cè)特定瀏覽器的能力。例如,腳本在調(diào)用某個(gè)函數(shù)之前,可能要先檢測(cè)該函數(shù)首付存在。這種檢測(cè)方法將開(kāi)發(fā)人員從考慮具體的瀏覽器類型和版本中解放出來(lái),讓他們把注意力集中到相應(yīng)的能力是否存在上。能力檢測(cè)無(wú)法精確地檢測(cè)特定的瀏覽器和版本。
怪癖檢測(cè)
怪癖實(shí)際上是瀏覽器實(shí)現(xiàn)中存在的bug,例如早期的webkit中就存在一個(gè)怪癖,即它會(huì)再for-in循環(huán)中返回被隱藏的屬性。怪癖檢測(cè)通常涉及到運(yùn)行一段代碼,然后確定瀏覽器是否存在某個(gè)怪癖。由于怪癖檢測(cè)無(wú)法精確地檢測(cè)特定的瀏覽器和版本。
用戶代理檢測(cè)
通過(guò)檢測(cè)用戶代理字符串來(lái)識(shí)別瀏覽器。用戶代理字符串中包含大量與瀏覽器有關(guān)的信息,包括瀏覽器、平臺(tái)、操作系統(tǒng)及瀏覽器版本。用戶代理字符串有過(guò)一段相當(dāng)長(zhǎng)的發(fā)展歷史,在此期間,瀏覽器提供商視圖通過(guò)在用戶代理字符串總添加一些欺騙性信息,欺騙網(wǎng)站詳細(xì)自己的瀏覽器是另外一種瀏覽器。用戶代理檢測(cè)需要特殊的技巧,特別是要注意Opera會(huì)隱瞞其用戶代理字符串的情況。即便如此,通過(guò)用戶代理字符串仍然能夠檢測(cè)出瀏覽器所用的呈現(xiàn)引擎以及所在的平臺(tái),包括移動(dòng)設(shè)備和游戲系統(tǒng)。
在每一次HTTP請(qǐng)求過(guò)程中,用戶代理字符串是作為響應(yīng)首部發(fā)送的,而且該字符串可以通過(guò)Javascript的navigator.userAgent屬性訪問(wèn)。在服務(wù)器端,通過(guò)檢測(cè)用戶代理字符串來(lái)確定用戶使用的瀏覽器是一種常用而且廣為接受的做法。而在客戶端,用戶代理檢測(cè)一般被當(dāng)作一種萬(wàn)不得已的做法,其優(yōu)先級(jí)排在能力檢測(cè)和怪癖檢測(cè)之后。
var client = function(){
// 呈現(xiàn)引擎
var engine = {
ie:0,
gecko:0,
webkit:0,
khtml:0,
opera:0,
// 完整的版本號(hào)
ver:null
};
// 瀏覽器
var browser = {
// 主要瀏覽器
ie:0,
firefox:0,
safari:0,
konq:0,
opera:0,
chrome:0,
// 具體的版本號(hào)
ver:null
};
// 檢測(cè)呈現(xiàn)引擎和瀏覽器
var ua = navigator.userAgent;
if (window.opera) {
engine.ver = browser.ver = window.opera.version();
engine.opera = browser.opera = parseFloat(engine.ver);
} else if (/AppleWebKit\/(\S+)/.test(ua)) {
engine.ver = RegExp["$1"];
engine.webkit = parseFloat(engine.ver);
// 確定是Chrome還是Safari
if (/Chrome\/(\S+)/.test(ua)) {
browser.ver = RegExp["$1"];
browser.chrome = parseFloat(engine.ver);
} else if (/Version\/(S+)/.test(ua)) {
browser.ver = RegExp["$1"];
browser.safari = parseFloat(browser.ver);
} else {
// 近似地確定版本號(hào)
var safariVersion = 1;
if (engine.Webkit <100) {
safariVersion = 1;
} else if (engine.webkit < 312) {
safariVersion = 1.2;
} else if (engine.webkit < 412) {
safariVersion = 1.3;
} else {
safariVersion = 2;
}
browser.safari = browser.ver = safariVersion;
}
} else if (/KHTML\/(S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)) {
engine.ver = browser.ver = RegExp["$1"];
engine.khtml = browser.kong = parseFloat(engine.ver);
} else if (/rv:([^\)]+)\) Gecko\/\d{8}/.test(ua)){
engine.ver = RegExp["$1"];
engine.gecko = parseFloat(engine.ver);
// 確定是不是firefox
if (/Firefox\/(S+)/.test(ua)) {
browser.ver = RegExp["$1"];
browser.firefox = parseFloat(browser.ver);
}
} else if (/MSIE ([^;]+)/.test(ua)) {
engine.ver = browser.ver = RegExp["$1"];
engine.ie = browser.ie = parseFloat(engine.ver);
}
// 檢測(cè)瀏覽器
browser.ie = engine.ie;
browser.opera = engine.opera;
// 返回這些對(duì)象
return {
engine:engine,
browser: browser
}
}();
console.log(client.engine);
console.log(client.browser);
Tangram 檢測(cè)瀏覽器源碼
/**
* 聲明baidu包
*/
var baidu = baidu || {version: "1-3-2"}; // meizz 20100513 將 guid 升級(jí)成 \x06
baidu.guid = "$BAIDU$";//提出guid,防止修改window[undefined] 20100504 berg
/**
* meizz 2010/02/04
* 頂級(jí)域名 baidu 有可能被閉包劫持,而需要頁(yè)面級(jí)唯一信息時(shí)需要用到下面這個(gè)對(duì)象
*/
window[baidu.guid] = window[baidu.guid] || {};
/**
* 聲明baidu.browser包
*/
baidu.browser = baidu.browser || {};
/**
* 判斷是否為isGecko
*/
baidu.browser.isGecko = /gecko/i.test(navigator.userAgent) && !/like gecko/i.test(navigator.userAgent);
/**
* 判斷是否為isWebkit
*/
baidu.browser.isWebkit = /webkit/i.test(navigator.userAgent);
/**
* 判斷是否為標(biāo)準(zhǔn)模式
*/
baidu.browser.isStrict = document.compatMode == "CSS1Compat";
/**
* 判斷是否為safari瀏覽器
*/
if ((/(\d+\.\d)(\.\d)?\s+safari/i.test(navigator.userAgent) && !/chrome/i.test(navigator.userAgent))) {
baidu.browser.safari = parseFloat(RegExp['\x241']);
}
/**
* 判斷是否為opera瀏覽器
*/
if (/opera\/(\d+\.\d)/i.test(navigator.userAgent)) {
baidu.browser.opera = parseFloat(RegExp['\x241']);
}
/**
* 判斷是否為chrome瀏覽器
*/
if (/chrome\/(\d+\.\d)/i.test(navigator.userAgent)) {
baidu.browser.chrome = parseFloat(RegExp['\x241']);
}
/**
* 判斷是否為ie瀏覽器
*/
if (/msie (\d+\.\d)/i.test(navigator.userAgent)) {
baidu.ie = baidu.browser.ie = document.documentMode || parseFloat(RegExp['\x241']);
}
/**
* 判斷是否為firefox瀏覽器
*/
if (/firefox\/(\d+\.\d)/i.test(navigator.userAgent)) {
baidu.browser.firefox = parseFloat(RegExp['\x241']);
// '\x241' 是八進(jìn)制表示法 '\x24' 對(duì)應(yīng)字符 '$' ,所以 '\x241' 等同于 '$1'
}
- js阻止瀏覽器默認(rèn)行為觸發(fā)的通用方法(推薦)
- js阻止瀏覽器默認(rèn)行為的簡(jiǎn)單實(shí)例
- 基于JS判斷iframe是否加載成功的方法(多種瀏覽器)
- js根據(jù)手機(jī)客戶端瀏覽器類型,判斷跳轉(zhuǎn)官網(wǎng)/手機(jī)網(wǎng)站多個(gè)實(shí)例代碼
- js判斷手機(jī)瀏覽器操作系統(tǒng)和微信瀏覽器的方法
- 瀏覽器兼容的JS寫(xiě)法總結(jié)
- 淺析JavaScript中瀏覽器的兼容問(wèn)題
- JS區(qū)分瀏覽器頁(yè)面是刷新還是關(guān)閉
- JS動(dòng)態(tài)改變?yōu)g覽器標(biāo)題的方法
- JavaScript 瀏覽器兼容性總結(jié)及常用瀏覽器兼容性分析
- 詳解javascript跨瀏覽器事件處理程序
- js事件處理程序跨瀏覽器解決方案
- js阻止默認(rèn)瀏覽器行為與冒泡行為的實(shí)現(xiàn)代碼
相關(guān)文章
JavaScript可折疊區(qū)域?qū)崿F(xiàn)代碼
可折疊區(qū)域的基本思想:通過(guò)點(diǎn)擊某個(gè)地方來(lái)顯示或隱藏屏幕中的某個(gè)區(qū)域。2010-10-10
JS特效實(shí)現(xiàn)圖片自動(dòng)播放并可控的效果
這篇文章主要介紹了JS代碼實(shí)現(xiàn)圖片自動(dòng)播放并可控的效果,需要的朋友可以參考下2015-07-07
js預(yù)載入和JavaScript Image()對(duì)象使用介紹
為了解決在canvas使用drawImage()時(shí),遇到img對(duì)象來(lái)不及加載的問(wèn)題; 我最終在html文檔加載中,使用了下面"數(shù)組加載圖像的辦法”解決,如果有其他方法,請(qǐng)給予指點(diǎn)!2011-08-08
javaScript 實(shí)現(xiàn)重復(fù)輸出給定的字符串的常用方法小結(jié)
這篇文章主要介紹了javaScript 實(shí)現(xiàn)重復(fù)輸出給定的字符串的常用方法,總結(jié)分析了JavaScript重復(fù)輸出給定字符串的4種常見(jiàn)操作技巧,需要的朋友可以參考下2020-02-02
JS中檢測(cè)數(shù)據(jù)類型的幾種方式及優(yōu)缺點(diǎn)小結(jié)
這篇文章主要介紹了JS中檢測(cè)數(shù)據(jù)類型的幾種方式及優(yōu)缺點(diǎn)小結(jié),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12
javascript寫(xiě)的一個(gè)模擬閱讀小說(shuō)的程序
這篇文章主要介紹了用javascript寫(xiě)了一個(gè)模擬閱讀小說(shuō)的程序,需要的朋友可以參考下2014-04-04
用正則表達(dá)式 動(dòng)態(tài)創(chuàng)建/增加css style script 兼容IE firefox
動(dòng)態(tài)創(chuàng)建/增加css style script 用正則表達(dá)式 兼容IE firefox2009-03-03
Javascript實(shí)現(xiàn)簡(jiǎn)單的富文本編輯器附演示
這篇文章主要介紹了通過(guò)Javascript實(shí)現(xiàn)的簡(jiǎn)單富文本編輯器,需要的朋友可以參考下2014-06-06
JavaScript腳本語(yǔ)言是什么_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
JavaScript是什么?這篇文章主要介紹了一種廣泛用于客戶端Web開(kāi)發(fā)的腳本語(yǔ)言JavaScript,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06

