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 ),
    
  • 相关阅读:
    解决:oracle+myBatis ResultMap 类型为 map 时,表字段类型有 Long/Blob/Clob 时报错
    总结:独立开发 jar 包组件——功能主要是支持查询数据库的所有表数据
    解决 iframe 后退不是主页面后退(浏览器 history)问题
    解决访问 jar 包里面的字体报错:OTS parsing error: incorrect file size in WOFF header
    html 如何访问 jar 包里面的静态资源(js、css、字体等)
    css3 实现打字机效果
    js 图形验证码
    input 设置 flex:1不起作用
    vue 样式加scoped不起作用
    node-mongoose开发中常见警告或问题-持续更新
  • 原文地址:https://www.cnblogs.com/fayin/p/6555929.html
Copyright © 2011-2022 走看看