js识别不同浏览器基于userAgent做判断


Posted in Javascript onJuly 29, 2014

检测浏览器,注意浏览器判断顺序,主要是基于userAgent做判断。

//检测浏览器
var client = function(){
var engine = {
ie:0,
gecko:0,
webkit:0,
khtml:0,
opera:0,
ver:null
};
var browser = {
//浏览器
ie: 0,
firefox: 0,
safari: 0,
konq: 0,
opera: 0,
chrome: 0,
ver:null
};
var ua = navigator.userAgent;
//浏览器检测有顺序
if(window.opera){//opera伪装,所以优先检测
engine.ver = browser.ver = window.opera.version();
engine.opera = browser.opera = parseFloat(engine.ver);
} else if(/AppleWebKit\/(\S+)/.test(ua)){
engine.ver = RegExp["$1"];
engine.webkit = parseFloat(engine.ver);


//确定是 Chrome 还是 Safari
if (/Chrome\/(\S+)/.test(ua)){
browser.ver = RegExp["$1"];
browser.chrome = parseFloat(browser.ver);
} else if (/Version\/(\S+)/.test(ua)){
browser.ver = RegExp["$1"];
browser.safari = parseFloat(browser.ver);
} else {
//近似地确定版本号
var safariVersion = 1;
if (engine.webkit < 100){
safariVersion = 1;
} else if (engine.webkit < 312){
safariVersion = 1.2;
} else if (engine.webkit < 412){
safariVersion = 1.3;
} else {
safariVersion = 2;
}


browser.safari = browser.ver = safariVersion;
}

}else if (/KHTML\/(\S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)){
engine.ver = browser.ver = RegExp["$1"];
engine.khtml = browser.konq = parseFloat(engine.ver);
}else if (/rv:([^\)]+)\) Gecko\/\d{8}/.test(ua)){
engine.ver = RegExp["$1"];
engine.gecko = parseFloat(engine.ver);
//确定是不是 Firefox
if (/Firefox\/(\S+)/.test(ua)){
browser.ver = RegExp["$1"];
browser.firefox = parseFloat(browser.ver);
}
}else if (/MSIE ([^;]+)/.test(ua)){
engine.ver = browser.ver = RegExp["$1"];
engine.ie = browser.ie = parseFloat(engine.ver);
}
return {
engine:engine,
browser: browser
};
}();


//调用

if (client.engine.webkit) { //if it's WebKit 
if (client.browser.chrome){ 
//执行针对 Chrome 的代码 
} else if (client.browser.safari){ 
//执行针对 Safari 的代码 
} 
} else if (client.engine.gecko){ 
if (client.browser.firefox){ 
//执行针对 Firefox 的代码 
} else { 
//执行针对其他 Gecko 浏览器的代码 
} 
}
Javascript 相关文章推荐
jQuery live( type, fn ) 委派事件实现
Oct 11 Javascript
js 兼容多浏览器的回车和鼠标焦点事件代码(IE6/7/8,firefox,chrome)
Apr 14 Javascript
JS中的public和private对象,即static修饰符
Jan 18 Javascript
js/jquery获取文本框输入焦点的方法
Mar 04 Javascript
5个书写JavaScript代码的坏习惯,看看你中枪了没?
Nov 06 Javascript
Javascript学习笔记之数组的构造函数
Nov 23 Javascript
跟我学习javascript的call(),apply(),bind()与回调
Nov 16 Javascript
整理Javascript事件响应学习笔记
Dec 02 Javascript
jQuery的中 is(':visible') 解析及用法(必看)
Feb 12 Javascript
详解Vue中一种简易路由传参办法
Sep 15 Javascript
判断滚动条滑到底部触发事件(实例讲解)
Nov 15 Javascript
Vue 根据条件判断van-tab的显示方式
Aug 03 Javascript
让浏览器DOM元素最后加载的js方法
Jul 29 #Javascript
js实现遮罩层划出效果是生成div而不是显示
Jul 29 #Javascript
解释&amp;&amp;和||在javascript中的另类用法
Jul 28 #Javascript
wap手机图片滑动切换特效无css3元素js脚本编写
Jul 28 #Javascript
jQuery内置的AJAX功能和JSON的使用实例
Jul 27 #Javascript
jQuery.parseJSON(json)将JSON字符串转换成js对象
Jul 27 #Javascript
jquery JSON的解析方式示例介绍
Jul 27 #Javascript
You might like
PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
2011/11/10 PHP
php并发对MYSQL造成压力的解决方法
2013/02/21 PHP
探讨:parse url解析URL,返回其组成部分
2013/06/14 PHP
php自定义的格式化时间示例代码
2013/12/05 PHP
Javascript实例教程(19) 使用HoTMetal(2)
2006/12/23 Javascript
js跟随滚动条滚动浮动代码
2009/12/31 Javascript
javascript学习笔记(八)正则表达式
2014/10/08 Javascript
jQuery 插件开发指南
2014/11/14 Javascript
JS实现判断碰撞的方法
2015/02/11 Javascript
jQuery封装的tab选项卡插件分享
2015/06/16 Javascript
JS封装的选项卡TAB切换效果示例
2016/09/20 Javascript
详解Javascript中的原型OOP
2016/10/12 Javascript
js中开关变量使用实例
2017/02/24 Javascript
js计算最大公约数和最小公倍数代码实例
2019/09/11 Javascript
JS回调函数深入理解
2019/10/16 Javascript
详解Python中__str__和__repr__方法的区别
2015/04/17 Python
python 获取网页编码方式实现代码
2017/03/11 Python
Python实现获取命令行输出结果的方法
2017/06/10 Python
python3 发送任意文件邮件的实例
2018/01/23 Python
DRF跨域后端解决之django-cors-headers的使用
2019/01/27 Python
python实现文件的分割与合并
2019/08/29 Python
python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法
2020/11/05 Python
有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题
2013/07/19 HTML / CSS
HTML5 拖放(Drag 和 Drop)详解与实例代码
2017/09/14 HTML / CSS
Gap加拿大官网:Gap Canada
2017/08/24 全球购物
英国皇室御用百货:福南梅森(Fortnum & Mason)
2017/12/03 全球购物
印度领先的眼镜电子商务网站:Lenskart
2019/12/16 全球购物
什么是虚拟内存?虚拟内存有什么优势?
2012/02/19 面试题
八年级音乐教学反思
2014/01/09 职场文书
投资合作协议书范本
2014/04/17 职场文书
企业党员一句话承诺
2014/05/30 职场文书
2014年后勤工作总结范文
2014/12/16 职场文书
2016母亲节感恩话语
2015/12/09 职场文书
2016廉洁从业学习心得体会
2016/01/19 职场文书
springboot项目以jar包运行的操作方法
2021/06/30 Java/Android
django项目、vue项目部署云服务器的详细过程
2022/07/23 Servers