zoukankan      html  css  js  c++  java
  • 【javascript】—— JS判断浏览器类型、操作系统

    navigator.userAgent : userAgent 属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值。

    navigator.platform : platform 属性是一个只读的字符串,声明了运行浏览器的操作系统和(或)硬件平台。

    判断浏览器类型

    IE浏览器

    ie = ua.match( /MSIEs([d.]+)/ ) || ua.match( /(?:trident)(?:.*rv:([w.]+))?/i ),

    IE浏览器版本号

    /msie 8.0/.test(navigator.userAgent.toLowerCase())

    微信浏览器

    /micromessenger/.test(navigator.userAgent.toLowerCase())

    chrome

    /chrome/.test(navigator.userAgent.toLowerCase())

    firefox

    /safari/.test(navigator.userAgent.toLowerCase())

    opera

    /micromessgenger/.test(navigator.userAgent.toLowerCase())

    判断操作系统类型

    win操作系统

     navigator.platform == "Win32"
     navigator.platform == "Windows"
    

    mac操作系统

         navigator.platform == "Mac68K"
         navigator.platform == "MacPPC"
         navigator.platform == "Macintosh"
         navigator.platform == "MacIntel"
    
    

    andorid操作系统

         if(/Linux/i.test(navigator.userAgent)){
             if(/android/i.test(navigator.userAgent.toLowerCase())){
                 return "android";
             }
         }
    
    /**
             * @description  简单的浏览器检查结果。
             *
             * * `webkit`  webkit版本号,如果浏览器为非webkit内核,此属性为`undefined`。
             * * `chrome`  chrome浏览器版本号,如果浏览器为chrome,此属性为`undefined`。
             * * `ie`  ie浏览器版本号,如果浏览器为非ie,此属性为`undefined`。**暂不支持ie10+**
             * * `firefox`  firefox浏览器版本号,如果浏览器为非firefox,此属性为`undefined`。
             * * `safari`  safari浏览器版本号,如果浏览器为非safari,此属性为`undefined`。
             * * `opera`  opera浏览器版本号,如果浏览器为非opera,此属性为`undefined`。
             *
             * @property {Object} [browser]
             */
            browser: (function( ua ) {
                var ret = {},
                    webkit = ua.match( /WebKit/([d.]+)/ ),
                    chrome = ua.match( /Chrome/([d.]+)/ ) ||
                        ua.match( /CriOS/([d.]+)/ ),
    
                    ie = ua.match( /MSIEs([d.]+)/ ) ||
                        ua.match( /(?:trident)(?:.*rv:([w.]+))?/i ),
                    firefox = ua.match( /Firefox/([d.]+)/ ),
                    safari = ua.match( /Safari/([d.]+)/ ),
                    opera = ua.match( /OPR/([d.]+)/ );
    
                webkit && (ret.webkit = parseFloat( webkit[ 1 ] ));
                chrome && (ret.chrome = parseFloat( chrome[ 1 ] ));
                ie && (ret.ie = parseFloat( ie[ 1 ] ));
                firefox && (ret.firefox = parseFloat( firefox[ 1 ] ));
                safari && (ret.safari = parseFloat( safari[ 1 ] ));
                opera && (ret.opera = parseFloat( opera[ 1 ] ));
    
                return ret;
            })( navigator.userAgent ),
    
            /**
             * @description  操作系统检查结果。
             *
             * * `android`  如果在android浏览器环境下,此值为对应的android版本号,否则为`undefined`。
             * * `ios` 如果在ios浏览器环境下,此值为对应的ios版本号,否则为`undefined`。
             * @property {Object} [os]
             */
            os: (function( ua ) {
                var ret = {},
    
                    // osx = !!ua.match( /(Macintosh; Intel / ),
                    android = ua.match( /(?:Android);?[s/]+([d.]+)?/ ),
                    ios = ua.match( /(?:iPad|iPod|iPhone).*OSs([d_]+)/ );
    
                // osx && (ret.osx = true);
                android && (ret.android = parseFloat( android[ 1 ] ));
                ios && (ret.ios = parseFloat( ios[ 1 ].replace( /_/g, '.' ) ));
    
                return ret;
            })( navigator.userAgent ),
    
  • 相关阅读:
    iNeuOS工业互联网系统,一键部署,5分钟内开箱即用
    演讲的要义
    在MyBatis中实现动态表名
    Pandora Boot和Spring Boot
    java对象克隆以及深拷贝和浅拷贝
    超级快的端口扫描工具blackwater
    webgl智慧楼宇发光系列之线性采样下高斯模糊
    canvas可视化效果之内阴影效果
    图表绘制之RepeatNode的妙用
    【ECUG】十四年如一日,有这样一群初心不改的技术人
  • 原文地址:https://www.cnblogs.com/fayin/p/6555929.html
Copyright © 2011-2022 走看看