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,这个很是变态,自己看着处理吧

  • 相关阅读:
    封装的图片预加载,数据加载到浏览器底部加载数据
    自己封装的弹出层插件
    在规定的时间内出现动画.html
    WEB前端资源集
    前端优化几项
    移动H5前端性能优化指南
    微信小程序IDE(微信web开发者工具)安装、破解手册--转载
    微信小程序开发—快速掌握组件及API的方法---转载
    STM32数据类型定义
    HDOJ 4802 GPA
  • 原文地址:https://www.cnblogs.com/sallet/p/4378052.html
Copyright © 2011-2022 走看看