美文网首页前端知识点
JS测试浏览器平台,并存为全局变量,方便后续调用@令狐张豪

JS测试浏览器平台,并存为全局变量,方便后续调用@令狐张豪

作者: 令狐张豪 | 来源:发表于2019-08-19 01:42 被阅读0次
    通过判断浏览器的userAgent,用正则来判断是否是ios和Android客户端。代码如下:
    <script>
        // JS测试浏览器平台,并存为全局变量,方便后续调用,0为安卓,1为ios,2为PC
    
        // 第一种:通过判断浏览器的userAgent,用正则来判断是否是ios和Android客户端。代码如下:
        // navigator ==>浏览器的所有信息(对象包含有关浏览器的信息)
        // userAgent ==>属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值。
        var platFlag = testPlat();
    
        function testPlat() {
            var u = navigator.userAgent;
            if (u.indexOf('Android') > -1 || u.indexOf('Adr') > -1) { //android终端
                setWebViewFlag();
                return '安卓';
            } else if (!!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/)) { //ios终端
                setWebViewFlag();
                return 'IOS';
            } else {
                return 'PC';
            }
        }
        alert(testPlat())            
    </script>
    
    检查是否是移动端(Mobile)、ipad、iphone、微信、QQ等
    <script type="text/javascript">
    //判断访问终端
    var browser={
        versions:function(){
            var u = navigator.userAgent, 
                app = navigator.appVersion;
            return {
                trident: u.indexOf('Trident') > -1, //IE内核
                presto: u.indexOf('Presto') > -1, //opera内核
                webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
                gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1,//火狐内核
                mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
                ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
                android: u.indexOf('Android') > -1 || u.indexOf('Adr') > -1, //android终端
                iPhone: u.indexOf('iPhone') > -1 , //是否为iPhone或者QQHD浏览器
                iPad: u.indexOf('iPad') > -1, //是否iPad
                webApp: u.indexOf('Safari') == -1, //是否web应该程序,没有头部与底部
                weixin: u.indexOf('MicroMessenger') > -1, //是否微信 (2015-01-22新增)
                qq: u.match(/\sQQ/i) == " qq" //是否QQ
            };
        }(),
        language:(navigator.browserLanguage || navigator.language).toLowerCase()
    }
        console.log(browser)
    </script>
    

    相关文章

      网友评论

        本文标题:JS测试浏览器平台,并存为全局变量,方便后续调用@令狐张豪

        本文链接:https://www.haomeiwen.com/subject/fkdjsctx.html