Js 获取、判断浏览器版本信息的简单方法
Navigator对象包含有关浏览器的信息:
•appCodeName--浏览器代码名的字符串表示
•appName--官方浏览器名的字符串表示
•appVersion--浏览器版本信息的字符串表示
•cookieEnabled--如果启用cookie返回true,否则返回false
•javaEnabled--如果启用java返回true,否则返回false
•platform--浏览器所在计算机平台的字符串表示
•plugins--安装在浏览器中的插件数组
•taintEnabled--如果启用了数据污点返回true,否则返回false
•userAgent--用户代理头的字符串表示
navigator中最重要的是userAgent属性,返回包含浏览器版本等信息的字符串;
cookieEnabled也很重要,使用它可以判断用户浏览器是否开启cookie。
javaScript判断浏览器类型一般有两种办法,一种是根据各种浏览器独有的属性来分辨,另一种是通过分析浏览器的userAgent属性来判断(版本只能通过分析userAgent获得);
只有在浏览器类型和浏览器版本都判断出后,才能处理兼容性问题。
1、通过userAgent中的特征来判断浏览器类型及版本(常用、保险做法)
functiongetBrowserInfo(){ varSys={}; varua=navigator.userAgent.toLowerCase(); vars;(s=ua.match(/msie([\d.]+)/))?Sys.ie=s[1]: (s=ua.match(/firefox\/([\d.]+)/))?Sys.firefox=s[1]: (s=ua.match(/chrome\/([\d.]+)/))?Sys.chrome=s[1]: (s=ua.match(/opera.([\d.]+)/))?Sys.opera=s[1]: (s=ua.match(/version\/([\d.]+).*safari/))?Sys.safari=s[1]:0; if(Sys.ie){ return'IE:'+Sys.ie; } if(Sys.firefox){ return'Firefox:'+Sys.firefox; } if(Sys.chrome){ return'Chrome:'+Sys.chrome; } if(Sys.opera){ return'Opera:'+Sys.opera; } if(Sys.safari){ return'Safari:'+Sys.safari; } } varbrowser=getBrowserInfo(); varverinfo=(browser+"").replace(/[^0-9.]/ig,"");//版本号
注意:一些浏览器的userAgent属性值中Chrome、Safari皆有,是因为Chrome的userAgent还包含了Safari的特征,因此这可能是Chrome可运行Safari浏览器应用的基础的原因。
2、通过各浏览器独有特性来分辨浏览器(需注意:这些特征可能会随浏览器版本而变化,或是其他浏览器也就可能跟着加入该特性,从而导致判断失败)
IE:只有IE支持创建ActiveX控件,所以ActiveXObject函数是其他浏览器没有的。只需判断window对象存在ActiveXObject函数,就明确判断出当前浏览器是IE。
Firefox:FF中的DOM元素都有一个getBoxObjectFor函数,用来获取该DOM元素的位置和大小。这是Firefox独有的,判断它即可分辨当前浏览器是Firefox。(IE对应的中是getBoundingClientRect函数)
Opera:Opera提供了专门的浏览器标志--window.opera属性。
Safari:openDatabase函数是其他浏览器没有的,可做为判断Safari的标志。
Chrome:和FF一样都一个MessageEvent函数,但Chrome并没有FF的getBoxObjectFor函数,根据这两个条件可判断Chrome浏览器。
varSys={}; varua=navigator.userAgent.toLowerCase(); if(window.ActiveXObject){ Sys.ie=ua.match(/msie([\d.]+)/)[1] }elseif(document.getBoxObjectFor){ Sys.firefox=ua.match(/firefox\/([\d.]+)/)[1] }elseif(window.MessageEvent&&!document.getBoxObjectFor){ Sys.chrome=ua.match(/chrome\/([\d.]+)/)[1] }elseif(window.opera){ Sys.opera=ua.match(/opera.([\d.]+)/)[1] }elseif(window.openDatabase){ Sys.safari=ua.match(/version\/([\d.]+)/)[1]; }
水平有限,文中错误不妥在所难免,欢迎批评指正建议评论。文章将不定期修改完善斧正。谢谢!
以上这篇Js获取、判断浏览器版本信息的简单方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。