zoukankan      html  css  js  c++  java
  • JavaScript 判断浏览器及版本

    /*
    智能机浏览器版本信息:
    alert("语言版本: "+browser.language);
    alert(" 是否为移动终端: "+browser.versions.mobile);
    alert(" ios终端: "+browser.versions.ios);
    alert(" android终端: "+browser.versions.android);
    alert(" 是否为iPhone: "+browser.versions.iPhone);
    alert(" 是否iPad: "+browser.versions.iPad);
    alert(navigator.userAgent);
    */
    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.*/)||!!u.match(/AppleWebKit/), //是否为移动终端
    	                ios: !!u.match(/(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
    	                android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器
    	                iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者QQHD浏览器
    	                iPad: u.indexOf('iPad') > -1, //是否iPad
    	                webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部
    	            };
    	         }(),
    	         language:(navigator.browserLanguage || navigator.language).toLowerCase()
    	}; 
    

      

    对于手机浏览器判断

    1.如何判断是否为移动终端 利用正则match

    匹配navigator.userAgent是否含有字符串AppleWebKit*****Mobile

    安卓qq浏览器HD版 只有AppleWebKit

    2手机语言版本的判断

    使用navigator.browserLanguage 便可得出windows phone语言版本, 
    当然可恶的小小手机语言版本也有兼容性的差异,兼容Mozilla,以及AppleWebKit内核的浏览器访问其语言版本,它会列出 navigator.language

    比较特别的地方

    UC浏览器没有安卓报头,只返回:linux ,这里粗略的根据linux来判断是安卓(前提必须满足是移动终端,UC这点是满足的)

    安卓QQ浏览器HD版检测的结果是:mac, Safari,这个很是变态,自己看着处理吧

  • 相关阅读:
    python接口自动化33-json解析神器jsonpath
    python测试开发django-79.ORM查询之datetime()格式化(extra )
    python测试开发django-78.ORM查询之extra
    python测试开发django-77.ORM如何添加 DateTimeField 不显示毫秒
    python测试开发django-76.ORM查询之Q查询
    python测试开发django-75.ORM根据日期查询(__range)
    Mysql 跨库数据迁移 -- python 脚本
    Mysql 视图
    mysql update select 从查询结果中更新数据
    Elastic Stack 入门
  • 原文地址:https://www.cnblogs.com/sallet/p/4378052.html
Copyright © 2011-2022 走看看