js识别不同浏览器

Posted jhcelue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js识别不同浏览器相关的知识,希望对你有一定的参考价值。

检測浏览器。注意浏览器推断顺序,主要是基于userAgent做推断。

//检測浏览器

var client = function(){
    var engine = {
        ie:0,
        gecko:0,
        webkit:0,
        khtml:0,
        opera:0,
        ver:null
    };
    var browser = {
        //浏览器
        ie: 0,
        firefox: 0,
        safari: 0,
        konq: 0,
        opera: 0,
        chrome: 0,
        ver:null
    };
    var ua = navigator.userAgent;
    //浏览器检測有顺序
    if(window.opera){//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(browser.ver);
        } else if (/Version\/(\S+)/.test(ua)){
            browser.ver = RegExp["$1"];
            browser.safari = parseFloat(browser.ver);
        } else {
            //近似地确定版本
            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.konq = 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);
    }
    return {
        engine:engine,
        browser: browser
    };
}();


//调用

if (client.engine.webkit) { //if it’s WebKit 
 if (client.browser.chrome){ 
 //运行针对 Chrome 的代码 
 } else if (client.browser.safari){ 
 //运行针对 Safari 的代码 
 } 
} else if (client.engine.gecko){ 
 if (client.browser.firefox){ 
 //运行针对 Firefox 的代码 
 } else { 
 //运行针对其它 Gecko 浏览器的代码 
 } 



























































































以上是关于js识别不同浏览器的主要内容,如果未能解决你的问题,请参考以下文章

JS笔记 BOM之Navigator 对象(识别不同的浏览器)

web学习记录-JS-14

[转] web前端js构造无法销毁的类UUID识别码,识别浏览器设备唯一性

浏览器兼容处理(HTML条件注释CSSHack和JS识别)

js网页判断移动终端浏览器版本信息是安卓还是苹果ios,判断在微信浏览器跳转不同页面,生成二维码

js识别安卓和ios及pc端,以及解决微信的屏蔽