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 相关文章推荐
brook javascript框架介绍
Oct 10 Javascript
原生js三级联动的简单实现代码
Jun 07 Javascript
vue2.0父子组件间通信的实现方法
Apr 19 Javascript
vue.js删除动态绑定的radio的指定项
Jun 02 Javascript
Webpack常见静态资源处理-模块加载器(Loaders)+ExtractTextPlugin插件
Jun 29 Javascript
Vue页面骨架屏的实现方法
May 22 Javascript
vue调试工具vue-devtools安装及使用方法
Nov 07 Javascript
jQuery实现的导航条点击后高亮显示功能示例
Mar 04 jQuery
Vue js 的生命周期(看了就懂)(推荐)
Mar 29 Javascript
小程序登录之支付宝授权的实现示例
Dec 13 Javascript
Vue循环中多个input绑定指定v-model实例
Aug 31 Javascript
Vue+Bootstrap收藏(点赞)功能逻辑与具体实现
Oct 22 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获取字符串的编码格式的方法(函数)
2013/06/21 PHP
Smarty中的注释和截断功能介绍
2015/04/09 PHP
PHP Streams(流)详细介绍及使用
2015/05/12 PHP
PHP实现支持加盐的图片加密解密
2016/09/09 PHP
php 开发中加密的几种方法总结
2017/03/22 PHP
php并发加锁问题分析与设计代码实例讲解
2021/02/26 PHP
js 判断脚本加载完毕的代码
2011/07/13 Javascript
jQuery $.data()方法使用注意细节
2012/12/31 Javascript
node.js中的emitter.on方法使用说明
2014/12/10 Javascript
jquery.gridrotator实现响应式图片展示画廊效果
2015/06/23 Javascript
谈谈JavaScript中的几种借用方法
2016/08/09 Javascript
使用bootstrap实现多窗口和拖动效果
2016/09/22 Javascript
String字符串截取的四种方式总结
2016/11/28 Javascript
Vue中img的src属性绑定与static文件夹实例
2017/05/18 Javascript
nodejs 如何手动实现服务器
2018/08/20 NodeJs
vue-cli3中配置alias和打包加hash值操作
2020/09/04 Javascript
vue3.0封装轮播图组件的步骤
2021/03/04 Vue.js
Python入门篇之编程习惯与特点
2014/10/17 Python
Python通过select实现异步IO的方法
2015/06/04 Python
python3 遍历删除特定后缀名文件的方法
2018/04/23 Python
解决pandas使用read_csv()读取文件遇到的问题
2018/06/15 Python
python 实现倒排索引的方法
2018/12/25 Python
Centos部署django服务nginx+uwsgi的方法
2019/01/02 Python
python实现最小二乘法线性拟合
2019/07/19 Python
python爬虫 urllib模块发起post请求过程解析
2019/08/20 Python
使用Django xadmin 实现修改时间选择器为不可输入状态
2020/03/30 Python
Python selenium文件上传下载功能代码实例
2020/04/13 Python
DeinDesign德国:设计自己的手机壳
2019/12/14 全球购物
广州迈达威.net面试题目
2012/03/10 面试题
介绍一下Linux中的链接
2016/05/28 面试题
竞聘副主任科员演讲稿
2014/01/11 职场文书
致裁判员加油稿
2014/02/08 职场文书
开业主持词
2014/03/21 职场文书
公司董事长岗位职责
2014/06/08 职场文书
2014年监理工作总结范文
2014/11/17 职场文书
2015年人力资源工作总结
2015/04/08 职场文书