首頁 >web前端 >js教程 >js判斷瀏覽器版本以及瀏覽器核心的方法_javascript技巧

js判斷瀏覽器版本以及瀏覽器核心的方法_javascript技巧

WBOY
WBOY原創
2016-05-16 16:18:561948瀏覽

本文實例講述了js判斷瀏覽器版本以及瀏覽器核心的方法。分享給大家供大家參考。具體實作方法如下:

複製程式碼 程式碼如下:

if (!browser.ie && !browser.mac) { 
 var UA = navigator.userAgent.toLowerCase().toString(); 
   //判斷是不是IE核心下的非IE版本 
if ((UA.indexOf('360ee') > -1) || (UA.indexOf('360se') > -1) || (UA.indexOf('se') > -1) || (UA. indexOf('aoyou') > -1) 
 || (UA.indexOf('theworld') > -1) || (UA.indexOf('worldchrome') > -1) || (UA.indexOf('greenbrowser') > -1) 
 || (UA.indexOf('baidu') > -1) || (UA.indexOf('qqbrowser') > -1)) { 
         //是的話切換相容模式 
    window.open("publicPage/point-se.aspx"); 
       } 
      else { 
             //不是的話,並建議更換瀏覽器 
           alert('建議換成IE核心的瀏覽器'); 
       } 
    } 
 else { 
            //判斷IE的版本型號 
            if ( (browser.version == 10 && browser.ie10Compat) || (browser.version == 11 && browser.ie1110Compat)) { 
                window.open("publicPage/point.aspx"); 
            } 
/* 
 * @desc   判斷瀏覽器的版本及瀏覽器核心 
 * @author wangyanling 
 * @date   2014年7月4日 
 */ 
 var browser = function () {  
    var agent = navigator.userAgent.toLowerCase(), 
    opera = window.opera, 
    browser = { 
        //偵測目前瀏覽器是否為IE 
        ie: /(msies|trident.*rv:)([w.] )/.test(agent), 

        //偵測目前瀏覽器是否為Opera 
        opera: (!!opera && opera.version), 

        //偵測目前瀏覽器是否為webkit核心的瀏覽器 
        webkit: (agent.indexOf(' applewebkit/') > -1), 

        //偵測目前瀏覽器是否運作在mac平台下 
        mac: (agent.indexOf('macintosh') > -1), 

        //偵測目前瀏覽器是否處於「怪異模式」下 
        quirks: (document.compatMode == 'BackCompat') 
    }; 

    //偵測目前瀏覽器核心是否為gecko核心 
    browser.gecko = (navigator.product == 'Gecko' && !browser.webkit && !browser.opera && !browser.ie); 

    var version = 0; 

    // Internet Explorer 6.0  
    if (browser.ie) { 
        var v1 = agent.match(/(?:msies([w.] ))/); 
        var v2 = agent.match(/(?:trident.*rv:([w.] ))/); 
        if (v1 && v2 && v1[1] && v2[1]) { 
            version = Math.max(v1[1] * 1, v2[1] * 1); 
        } else if (v1 && v1[1]) { 
            version = v1[1] * 1; 
        } else if (v2 && v2[1]) { 
            version = v2[1] * 1; 
        } else { 
            version = 0; 
        } 

        //偵測瀏覽器模式是否為 IE11 相容模式 
        browser.ie11Compat = document.documentMode == 11; 

        //偵測瀏覽器模式是否為 IE9 相容模式 
        browser.ie9Compat = document.documentMode == 9; 

        //偵測瀏覽器模式是否為 IE10 相容模式 
        browser.ie10Compat = document.documentMode == 10; 

        //偵測瀏覽器是否為IE8瀏覽器 
        browser.ie8 = !!document.documentMode; 

        //偵測瀏覽器模式是否為 IE8 相容模式 
        browser.ie8Compat = document.documentMode == 8; 

        //偵測瀏覽器模式是否為 IE7 相容模式 
        browser.ie7Compat = ((version == 7 && !document.documentMode) || document.documentMode == 7); 

        //偵測瀏覽器模式是否為 IE6 模式 或怪異模式 
        browser.ie6Compat = (version

        browser.ie9above = version > 8; 

        browser.ie9below = version     } 

    // Gecko. 
    if (browser.gecko) { 
        var geckoRelease = agent.match(/rv:([d.] )/); 
        if (geckoRelease) { 
            geckoRelease = geckoRelease[1].split('.'); 
            version = geckoRelease[0] * 10000 (geckoRelease[1] 0 0) * 100 (geckoRelease[2] || 0) * 1|| 0) * 100 (geckoRelease[2] || 0) * 1|| 
        } 
    } 

    //偵測目前瀏覽器是否為Chrome, 若是,則回傳Chrome的大版本號 
    if (/chrome/(d .d)/i.test(agent)) { 
        browser.chrome = RegExp['x241']; 
    } 

    //偵測目前瀏覽器是否為Safari, 如果是,則回傳Safari的大版本號 
    if (/(d .d)?(?:.d)?s safari/?(d .d )?/i.test(agent) && !/chrome/i.test(agent)) { 
        browser.safari = (RegExp['x241'] || RegExp['x242']); 
    } 

    // Opera 9.50  
    if (browser.opera) 
        version = parseFloat(opera.version()); 

    // WebKit 522 (Safari 3 ) 
    if (browser.webkit) 
        version = parseFloat(agent.match(/ applewebkit/(d )/)[1]); 

    //偵測目前瀏覽器版本號碼 
    browser.version = version; 

    return browser; 
}();

希望本文所述對大家的javascript程式設計有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn