javascript 检测浏览器类型和版本的代码


Posted in Javascript onSeptember 15, 2009

检测浏览器及其版本的代码

getBrowser : function(){ 
var browser = { 
msie: false, firefox: false, opera: false, safari: false, 
chrome: false, netscape: false, appname: 'unknown', version: 0 
}, 
userAgent = window.navigator.userAgent.toLowerCase(); 
if ( /(msie|firefox|opera|chrome|netscape)\D+(\d[\d.]*)/.test( userAgent ) ){ 
browser[RegExp.$1] = true; 
browser.appname = RegExp.$1; 
browser.version = RegExp.$2; 
} else if ( /version\D+(\d[\d.]*).*safari/.test( userAgent ) ){ // safari 
browser.safari = true; 
browser.appname = 'safari'; 
browser.version = RegExp.$2; 
} 
return browser.appname + browser.version; 
}

对象/特征检测法

该方法是一种判断浏览器能力(而非浏览器的确切型号)的通用方法。大部分JS专家认为这个方法最合适,因为他们认为按照该方法所编写的脚本是经得起未来考验的。

//获取IE浏览器的版本号
//返回数值,显示IE的主版本号
function getIEVer() {
var ua = navigator.userAgent; //获取用户端信息
var b = ua.indexOf("MSIE "); //检测特殊字符串"MSIE "的位置
if (b < 0) {
return 0;
}
return parseFloat(ua.substring(b + 5, ua.indexOf(";", b))); //截取版本号字符串,并转换为数值
}

alert(getIEVer()); //返回数值8(我的IE8)

如果更关注浏览器的能力而不在乎它实际的身份,就可以使用这种方法。

user-agent字符串检测法

user-agent字符串提供了关于Web浏览器的大量信息,包括浏览器的名称和版本。

var ua = navigator.userAgent.toLowerCase(); //获取用户端信息
var info = {
ie: /msie/.test(ua) && !/opera/.test(ua),  //匹配IE浏览器
op: /opera/.test(ua),  //匹配Opera浏览器
sa: /version.*safari/.test(ua),  //匹配Safari浏览器
ch: /chrome/.test(ua),  //匹配Chrome浏览器
ff: /gecko/.test(ua) && !/webkit/.test(ua)  //匹配Firefox浏览器
};
(info.ie) && alert("IE浏览器");
(info.op) && alert("Opera浏览器");
(info.sa) && alert("Safari浏览器");
(info.ff) && alert("Firefox浏览器");
(info.ch) && alert("Chrome浏览器");

通常我们做得最多的,就是判断是否是IE了,其它几种浏览器一般都会符合标准.有些客户只需要符合IE和FF就已经满足了.那么我们可以这样做:

var isIE = (navigator.appName == "Microsoft Internet Explorer");

判断IE远远不止上面一种方法,可以使用IE更多特有的东西,如:window.ActiveXObject,document.all等,这些都属于对象/特征检测法了!通常要在不同的浏览器上写不同的样式(因为IE样式解析也各有不同),那就得判断版本了.可以这样做

//获取IE浏览器的版本号
//返回数值,显示IE的主版本号
function getIEVer() {
var ua = navigator.userAgent; //获取用户端信息
var b = ua.indexOf("MSIE "); //检测特殊字符串"MSIE "的位置
if (b < 0) {
return 0;
}
return parseFloat(ua.substring(b + 5, ua.indexOf(";", b))); //截取版本号字符串,并转换为数值
}

alert(getIEVer()); //返回数值7

检测操作系统:

var isWin = (navigator.userAgent.indexOf("Win") != -1); //如果是Windows系统,则返回true
var isMac = (navigator.userAgent.indexOf("Mac") != -1);  //如果是Macintosh系统,则返回true
var isUnix = (navigator.userAgent.indexOf("X11") != -1);  //如果是Unix系统,则返回true
var isLinux = (navigator.userAgent.indexOf("Linux") != -1);  //如果是Linux系统,则返回true

文章大部分内容来自于《Javascript征途》

Javascript 相关文章推荐
Javascript的IE和Firefox兼容性汇编
Jul 01 Javascript
javascript innerHTML使用分析
Dec 03 Javascript
html向js方法传递参数具体实现
Aug 08 Javascript
JS如何判断移动端访问设备并解析对应CSS
Nov 27 Javascript
第五章之BootStrap 栅格系统
Apr 25 Javascript
深入浅析JS的数组遍历方法(推荐)
Jun 15 Javascript
全面了解JavaScript的数据类型转换
Jul 01 Javascript
jquery pagination分页插件使用详解(后台struts2)
Jan 22 Javascript
JavaScript实现时钟滴答声效果
Jan 29 Javascript
JS批量替换内容中关键词为超链接
Feb 20 Javascript
利用js定义一个导航条菜单
Mar 14 Javascript
element-ui table行点击获取行索引(index)并利用索引更换行顺序
Feb 27 Javascript
不安全的常用的js写法
Sep 15 #Javascript
Mootools 1.2教程 滑动效果(Slide)
Sep 15 #Javascript
Mootools 1.2教程 同时进行多个形变动画
Sep 15 #Javascript
Mootools 1.2教程(21)——类(二)
Sep 15 #Javascript
Mootools 1.2教程 选项卡效果(Tabs)
Sep 15 #Javascript
Mootools 1.2教程 Tooltips
Sep 15 #Javascript
Mootools 1.2教程 类(一)
Sep 15 #Javascript
You might like
PHP排序算法的复习和总结
2012/02/15 PHP
php中{}大括号是什么意思
2013/12/01 PHP
递归删除一个节点以及该节点下的所有节点示例
2014/03/19 PHP
php中fgetcsv()函数用法实例
2014/11/28 PHP
PHP实现八皇后算法
2019/05/06 PHP
jQuery EasyUI API 中文文档 搜索框
2011/09/29 Javascript
JS 表单验证大全
2011/11/23 Javascript
javascript与cookie 的问题详解
2013/11/11 Javascript
js substring从右边获取指定长度字符串(示例代码)
2013/12/23 Javascript
nw.js实现类似微信的聊天软件
2015/03/16 Javascript
Javascript中的方法和匿名方法实例详解
2015/06/13 Javascript
JavaScript中反正弦函数Math.asin()的使用简介
2015/06/14 Javascript
JavaScript获取表格(table)当前行的值、删除行、增加行
2015/07/03 Javascript
jquery插件uploadify多图上传功能实现代码
2016/08/12 Javascript
BootStrap 实现各种样式的进度条效果
2016/12/07 Javascript
JavaScript解析JSON格式数据的方法示例
2017/01/24 Javascript
vue.js移动数组位置,同时更新视图的方法
2018/03/08 Javascript
VUE实时监听元素距离顶部高度的操作
2020/07/29 Javascript
ant-design-vue中tree增删改的操作方法
2020/11/03 Javascript
使用python提取html文件中的特定数据的实现代码
2013/03/24 Python
Python中使用wxPython开发的一个简易笔记本程序实例
2015/02/08 Python
python+selenium开发环境搭建图文教程
2017/08/11 Python
Python实现按中文排序的方法示例
2018/04/25 Python
在python tkinter中Canvas实现进度条显示的方法
2019/06/14 Python
Python坐标线性插值应用实现
2019/11/13 Python
django-csrf使用和禁用方式
2020/03/13 Python
使用pymysql查询数据库,把结果保存为列表并获取指定元素下标实例
2020/05/15 Python
Nike西班牙官方网站:Nike.com (ES)
2017/10/30 全球购物
武汉英思工程科技有限公司&ndash;ORACLE面试测试题目
2012/04/30 面试题
网上蛋糕店创业计划书
2014/01/24 职场文书
投标承诺书范本
2014/03/27 职场文书
《微笑着面对生活》优秀演讲稿范文
2014/09/23 职场文书
如何利用Matlab制作一款真正的拼图小游戏
2021/05/11 Python
Vue过滤器(filter)实现及应用场景详解
2021/06/15 Vue.js
纯html+css实现奥运五环的示例代码
2021/08/02 HTML / CSS
Python实现自动玩连连看的脚本分享
2022/04/04 Python