當前位置:才華齋>設計>網頁設計>

分享jquery uaMatch原始碼

網頁設計 閱讀(5.48K)

jquery uaMatch原始碼

分享jquery uaMatch原始碼

複製程式碼 程式碼如下:

// Useragent RegExp

rwebkit = /(webkit)[ /]([w.]+)/,

ropera = /(opera)(?:.*version)?[ /]([w.]+)/,

rmsie = /(msie) ([w.]+)/,

rmozilla = /(mozilla)(?:.*? rv:([w.]+))?/,

// Keep a UserAgent string for use with ser

userAgent = Agent,

// For matching the engine and version of the browser

browserMatch,

// Use of ser is frowned upon.

// More details:

uaMatch: function( ua ) {

ua = werCase();

var match = ( ua ) ||

( ua ) ||

( ua ) ||

xOf("compatible") < 0 && ( ua ) ||

[];

return { browser: match[1] || "", version: match[2] || "0" };

}

browserMatch = tch( userAgent );

if ( ser ) {

ser[ ser ] = true;

ion = ion;

}

分析:瀏覽器之間的相容性問題,這個一個歷史遺留問題。痛苦的是,作為一個前端開發人員得為這個相容性問題買單。我們做開發時,往往要為每種瀏覽器作出區域性的程式碼調整才能在相應的瀏覽器中良好的執行。我所知道的方法有兩種:1.瀏覽器檢測;2.物件檢測。

在jQuery 中只要用行uaMatch()這個函式。用到的`關鍵點有:(str);Agent;

一,(str);用正則表示式來在字串中查詢,並返回一個數組,這個陣列的0元素是整個正則匹配,1元素是第一個子匹配,2元素是第二個子匹配,如此類推。

二,Agent:是javascript BOM的重要的物件之一,它主要用來返回當前的瀏覽器和作業系統的資訊。

例如:firefox的Agetn 的字串:"Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:) Gecko/20101203 Firefox/3.6.13"

IE8的Agetn的字串:"Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; CLR 1.1.4322; CLR 2.0.50727; CLR 3.0.4506.2152; CLR 3.5.30729)".

從各個瀏覽器的正則表示式可知,第一個子匹配為瀏覽器的名字,第二個為版本。