Js 获取、判断浏览器版本信息的简单方法


Posted in Javascript onAugust 08, 2016

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中的特征来判断浏览器类型及版本(常用、保险做法)

function getBrowserInfo() {
var Sys = {};

var ua = navigator.userAgent.toLowerCase();

var s; (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;

}
} 
var browser = getBrowserInfo() ;
var verinfo = (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浏览器。

var Sys = {};
var ua = navigator.userAgent.toLowerCase();
if(window.ActiveXObject) {
Sys.ie = ua.match(/msie ([\d.]+)/)[1]
}else if(document.getBoxObjectFor) {

Sys.firefox = ua.match(/firefox\/([\d.]+)/)[1]
}else if(window.MessageEvent && !document.getBoxObjectFor) {

Sys.chrome = ua.match(/chrome\/([\d.]+)/)[1]
}else if(window.opera) {

Sys.opera = ua.match(/opera.([\d.]+)/)[1]
}else if(window.openDatabase) {

Sys.safari = ua.match(/version\/([\d.]+)/)[1];
}

水平有限,文中错误不妥在所难免,欢迎批评指正建议评论。文章将不定期修改完善斧正。谢谢!

以上这篇Js 获取、判断浏览器版本信息的简单方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript倒计时代码
Aug 12 Javascript
同一个网页中实现多个JavaScript特效的方法
Feb 02 Javascript
JS+CSS实现仿触屏手机拨号盘界面及功能模拟完整实例
May 16 Javascript
JS使用parseInt解析数字实现求和的方法
Aug 05 Javascript
JavaScript引用类型和基本类型详解
Jan 06 Javascript
带有定位当前位置的百度地图前端web api实例代码
Jun 21 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
Oct 10 Javascript
vue解决跨域路由冲突问题思路解析
Nov 03 Javascript
vue动态绑定组件子父组件多表单验证功能的实现代码
May 14 Javascript
微信公众号H5支付接口调用方法
Jan 10 Javascript
vue中轮训器的使用
Jan 27 Javascript
Vue数据双向绑定原理实例解析
May 15 Javascript
基于BootStrap实现局部刷新分页实例代码
Aug 08 #Javascript
js智能获取浏览器版本UA信息的方法
Aug 08 #Javascript
jQuery.ajax 跨域请求webapi设置headers的解决方案
Aug 08 #Javascript
一个超简单的jQuery回调函数例子(分享)
Aug 08 #Javascript
Bootstrap Table服务器分页与在线编辑应用总结
Aug 08 #Javascript
使用jQuery5分钟快速搞定双色表格的简单实例
Aug 08 #Javascript
BootStrap Table 分页后重新搜索问题的解决办法
Aug 08 #Javascript
You might like
轻松入门: 煮好咖啡的七个诀窍
2021/03/03 冲泡冲煮
PHP遍历二维数组的代码
2011/04/22 PHP
五款常用mysql slow log分析工具的比较分析
2011/05/22 PHP
Linux环境下搭建php开发环境的操作步骤
2013/06/17 PHP
解析php中die(),exit(),return的区别
2013/06/20 PHP
ThinkPHP处理Ajax返回的方法
2014/11/22 PHP
PHP中的一些常用函数收集
2015/05/26 PHP
PHP获取中国时间(上海时区时间)及美国时间的方法
2017/02/23 PHP
PHP生成随机数的方法总结
2018/03/01 PHP
php5对象复制、clone、浅复制与深复制实例详解
2019/08/14 PHP
js正则表达式的使用详解
2013/07/09 Javascript
按Enter键触发事件的jquery方法实现代码
2014/02/17 Javascript
Jquery倒计时源码分享
2014/05/16 Javascript
BootStrapTable服务器分页实例解析
2016/12/20 Javascript
Express系列之multer上传的使用
2017/10/27 Javascript
Node.js使用MongoDB的ObjectId作为查询条件的方法
2019/09/10 Javascript
jQuery实现简单飞机大战
2020/07/05 jQuery
js里面的变量范围分享
2020/07/18 Javascript
vue在App.vue文件中监听路由变化刷新页面操作
2020/08/14 Javascript
解决ant-design-vue中menu菜单无法默认展开的问题
2020/10/31 Javascript
小结Python用fork来创建子进程注意事项
2014/07/03 Python
python/sympy求解矩阵方程的方法
2018/11/08 Python
基于numpy中的expand_dims函数用法
2019/12/18 Python
中国酒类在线零售网站:酒仙网
2016/08/20 全球购物
Merrell迈乐澳大利亚网站:购买户外登山鞋
2017/05/28 全球购物
香港卓悦化妆品官网:BONJOUR
2017/09/21 全球购物
埃弗顿足球俱乐部官方网上商店:Everton Direct
2018/01/13 全球购物
实习教师自我鉴定
2013/12/09 职场文书
学校运动会开幕演讲稿
2014/01/04 职场文书
幼儿园教师奖惩制度
2014/02/01 职场文书
美术毕业生求职信
2014/02/25 职场文书
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
美术课外活动总结
2014/07/08 职场文书
人工作失职检讨书
2015/05/05 职场文书
2015年社区反邪教工作总结
2015/10/14 职场文书
详解Java实践之适配器模式
2021/06/18 Java/Android