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 相关文章推荐
ASP.NET中使用后端代码注册脚本 生成JQUERY-EASYUI的界面错位的解决方法
Jun 12 Javascript
关于jQuery的inArray 方法介绍
Oct 08 Javascript
js判断浏览器类型的方法
Aug 07 Javascript
让javascript加载速度倍增的方法(解决JS加载速度慢的问题)
Dec 12 Javascript
window.open()实现post传递参数
Mar 12 Javascript
使用PHP+JavaScript将HTML页面转换为图片的实例分享
Apr 18 Javascript
详解XMLHttpRequest(二)响应属性、二进制数据、监测上传下载进度
Sep 14 Javascript
jQuery Chosen通用初始化
Mar 07 Javascript
JavaScript订单操作小程序完整版
Jun 23 Javascript
通过vue提供的keep-alive减少对服务器的请求次数
Apr 01 Javascript
React Native悬浮按钮组件的示例代码
Apr 05 Javascript
详解vue.js下引入百度地图jsApi的两种方法
Jul 27 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 Ajax中文乱码问题解决方法
2009/02/27 PHP
Yii把CGridView文本框换成下拉框的方法
2014/12/03 PHP
[原创]PHP实现生成vcf vcard文件功能类定义与使用方法详解【附demo源码下载】
2017/09/02 PHP
通过jquery实现tab标签浏览效果
2007/02/20 Javascript
一段实现页面上的图片延时加载的js代码
2010/02/11 Javascript
JavaScript 产生不重复的随机数三种实现思路
2012/12/13 Javascript
javascript操作html控件实例(javascript添加html)
2013/12/02 Javascript
让alert不出现弹窗的两种方法
2014/05/18 Javascript
被遗忘的javascript的slice() 方法
2015/04/20 Javascript
使用Meteor配合Node.js编写实时聊天应用的范例
2015/06/23 Javascript
javascript实现去除HTML标签的方法
2016/12/26 Javascript
bootstrap IE8 兼容性处理
2017/03/22 Javascript
详解在create-react-app使用less与antd按需加载
2018/12/06 Javascript
vue实现弹幕功能
2019/10/25 Javascript
js实现3D照片墙效果
2019/10/28 Javascript
Vue 使用iframe引用html页面实现vue和html页面方法的调用操作
2020/11/16 Javascript
[43:51]2014 DOTA2国际邀请赛中国区预选赛 Dream Times VS TongFu
2014/05/22 DOTA
python类继承与子类实例初始化用法分析
2015/04/17 Python
pytorch 把MNIST数据集转换成图片和txt的方法
2018/05/20 Python
基于树莓派的语音对话机器人
2019/06/17 Python
pyqt5 实现在别的窗口弹出进度条
2019/06/18 Python
浅谈Python中os模块及shutil模块的常规操作
2020/04/03 Python
什么是python类属性
2020/06/10 Python
德国机车企业:FC-Moto
2017/10/27 全球购物
美国保健品专家:Life Extension
2018/05/04 全球购物
英国女性时尚精品店:THE DRESSING ROOM
2018/05/23 全球购物
小学运动会广播稿200字(十二篇)
2014/01/14 职场文书
就业推荐表自我鉴定
2014/03/21 职场文书
文明演讲稿范文
2014/05/12 职场文书
学校社会实践活动总结
2014/07/03 职场文书
民主生活会发言材料
2014/10/20 职场文书
个人借条范本
2015/05/25 职场文书
焦裕禄观后感
2015/06/03 职场文书
《将心比心》教学反思
2016/02/23 职场文书
Golang 正则匹配效率详解
2021/04/25 Golang
原生JS中应该禁止出现的写法
2021/05/05 Javascript