javascript浏览器检测
<script type=
"text/javascript"
>
/**
* 获取浏览器类型以及版本号
* 支持国产浏览器:猎豹浏览器、搜狗浏览器、傲游浏览器、360极速浏览器、360安全浏览器、
* QQ浏览器、百度浏览器等.
* 支持国外浏览器:IE,Firefox,Chrome,safari,Opera等.
* 使用方法:
* 获取浏览器版本:Browser.client.version
* 获取浏览器名称(外壳):Browser.client.name
* @author:xuzengqiang
* @since :2015-1-27 10:26:11
**/
var Browser=Browser || (function(window){
var document = window.document,
navigator = window.navigator,
agent = navigator.userAgent.toLowerCase(),
//IE8+支持.返回浏览器渲染当前文档所用的模式
//IE6,IE7:undefined.IE8:8(兼容模式返回7).IE9:9(兼容模式返回7||8)
//IE10:10(兼容模式7||8||9)
IEMode = document.documentMode,
//chorme
chrome = window.chrome ||
false
,
System = {
//user-agent
agent : agent,
//是否为IE
isIE : /msie/.test(agent),
//Gecko内核
isGecko: agent.indexOf(
"gecko"
)>
0
&& agent.indexOf(
"like gecko"
)<
0
,
//webkit内核
isWebkit: agent.indexOf(
"webkit"
)>
0
,
//是否为标准模式
isStrict: document.compatMode ===
"CSS1Compat"
,
//是否支持subtitle
supportSubTitle:function(){
return
"track"
in document.createElement(
"track"
);
},
//是否支持scoped
supportScope:function(){
return
"scoped"
in document.createElement(
"style"
);
},
//获取IE的版本号
ieVersion:function(){
try
{
return
agent.match(/msie ([\d.]+)/)[
1
] ||
0
;
}
catch
(e) {
console.log(
"error"
);
return
IEMode;
}
},
//Opera版本号
operaVersion:function(){
try
{
if
(window.opera) {
return
agent.match(/opera.([\d.]+)/)[
1
];
}
else
if
(agent.indexOf(
"opr"
) >
0
) {
return
agent.match(/opr\/([\d.]+)/)[
1
];
}
}
catch
(e) {
console.log(
"error"
);
return
0
;
}
},
//描述:version过滤.如31.0.252.152 只保留31.0
versionFilter:function(){
if
(arguments.length ===
1
&& typeof arguments[
0
] ===
"string"
) {
var version = arguments[
0
];
start = version.indexOf(
"."
);
if
(start>
0
){
end = version.indexOf(
"."
,start+
1
);
if
(end !== -
1
) {
return
version.substr(
0
,end);
}
}
return
version;
}
else
if
(arguments.length ===
1
) {
return
arguments[
0
];
}
return
0
;
}
};
try
{
//浏览器类型(IE、Opera、Chrome、Safari、Firefox)
System.type = System.isIE?
"IE"
:
window.opera || (agent.indexOf(
"opr"
) >
0
)?
"Opera"
:
(agent.indexOf(
"chrome"
)>
0
)?
"Chrome"
:
//safari也提供了专门的判定方式
window.openDatabase?
"Safari"
:
(agent.indexOf(
"firefox"
)>
0
)?
"Firefox"
:
'unknow'
;
//版本号
System.version = (System.type ===
"IE"
)?System.ieVersion():
(System.type ===
"Firefox"
)?agent.match(/firefox\/([\d.]+)/)[
1
]:
(System.type ===
"Chrome"
)?agent.match(/chrome\/([\d.]+)/)[
1
]:
(System.type ===
"Opera"
)?System.operaVersion():
(System.type ===
"Safari"
)?agent.match(/version\/([\d.]+)/)[
1
]:
"0"
;
//浏览器外壳
System.shell=function(){
//遨游浏览器
if
(agent.indexOf(
"maxthon"
) >
0
) {
System.version = agent.match(/maxthon\/([\d.]+)/)[
1
] || System.version ;
return
"傲游浏览器"
;
}
//QQ浏览器
if
(agent.indexOf(
"qqbrowser"
) >
0
) {
System.version = agent.match(/qqbrowser\/([\d.]+)/)[
1
] || System.version ;
return
"QQ浏览器"
;
}
//搜狗浏览器
if
( agent.indexOf(
"se 2.x"
)>
0
) {
return
'搜狗浏览器'
;
}
//Chrome:也可以使用window.chrome && window.chrome.webstore判断
if
(chrome && System.type !==
"Opera"
) {
var external = window.external,
clientInfo = window.clientInformation,
//客户端语言:zh-cn,zh.360下面会返回undefined
clientLanguage = clientInfo.languages;
//猎豹浏览器:或者agent.indexOf("lbbrowser")>0
if
( external &&
'LiebaoGetVersion'
in external) {
return
'猎豹浏览器'
;
}
//百度浏览器
if
(agent.indexOf(
"bidubrowser"
)>
0
) {
System.version = agent.match(/bidubrowser\/([\d.]+)/)[
1
] ||
agent.match(/chrome\/([\d.]+)/)[
1
];
return
"百度浏览器"
;
}
//360极速浏览器和360安全浏览器
if
( System.supportSubTitle() && typeof clientLanguage ===
"undefined"
) {
//object.key()返回一个数组.包含可枚举属性和方法名称
var storeKeyLen = Object.keys(chrome.webstore).length,
v8Locale =
"v8Locale"
in window;
return
storeKeyLen >
1
?
'360极速浏览器'
:
'360安全浏览器'
;
}
return
"Chrome"
;
}
return
System.type;
};
//浏览器名称(如果是壳浏览器,则返回壳名称)
System.name = System.shell();
//对版本号进行过滤过处理
System.version = System.versionFilter(System.version);
}
catch
(e) {
console.log(
"error"
);
}
return
{
client:System
};
})(window);
alert(Browser.client.name+
" "
+Browser.client.version);
</script>
javascript浏览器检测的更多相关文章
- 第一百一十二节,JavaScript浏览器检测
JavaScript浏览器检测 学习要点: 1.navigator对象 2.客户端检测 由于每个浏览器都具有自己独到的扩展,所以在开发阶段来判断浏览器是一个非常重要的步骤.虽然浏览器开发商在公共接口方 ...
- JavaScript浏览器检测之navigator 对象
一.使用客户端检测的原因 由于每个浏览器都具有自己独到的扩展,所以在开发阶段来判断浏览器是一个非常重要的步骤. 虽然浏览器开发商在公共接口方面投入了很多精力,努力的去支持最常用的公共功能: 但在现实中 ...
- JavaScript浏览器检测之客户端检测
客户端检测一共分为三种,分别为:能力检测.怪癖检测和用户代理检测,通过这三种检测方案,我们可以充分的了解当前浏览器所处系统.所支持的语法.所具有的特殊性能. 一.能力检测: 能力检测又称作为特性检测, ...
- Javascript 浏览器检测
推荐 Browser Detecter, 很好用,自己也很容易扩展. 原文链接:http://www.quirksmode.org/js/detect.html <script type=&qu ...
- JavaScript(第十七天)【浏览器检测】
由于每个浏览器都具有自己独到的扩展,所以在开发阶段来判断浏览器是一个非常重要的步骤.虽然浏览器开发商在公共接口方面投入了很多精力,努力的去支持最常用的公共功能:但在现实中,浏览器之间的差异,以及不同浏 ...
- 第一百四十节,JavaScript,封装库--浏览器检测
JavaScript,封装库--浏览器检测 在函数库编写一个,浏览器检测对象 /** sys浏览器检测对象,对象下有两个属性,liu_lan_qi属性和xi_tong属性 * liu_lan_qi属性 ...
- 页面系统,浏览器检测- 网页基础模块(JavaScript)
// 浏览器检测,获取,弹出框提醒IE 返回浏览器详情 function GetbrowserSys() { var BrowserMatch = { init: function() { this. ...
- JavaScript功能检测技术和函数构造
Javascript与很多编程语言不同,它不能够控制其运行环境.再写php代码时,只要在服务器端部署了正确的版本,那么程序就绝对能够运行,对于其他python或ruby后端语言来说,也不存在什么灰色区 ...
- JavaScript交互式网页设计 • 【第3章 JavaScript浏览器对象模型】
全部章节 >>>> 本章目录 3.1 浏览器对象模型 3.1.1 浏览器对象模型 3.2 window 对象 3.2.1 window 对象的常用属性及方法 3.2.2 使 ...
随机推荐
- [Hadoop in Action] 第5章 高阶MapReduce
链接多个MapReduce作业 执行多个数据集的联结 生成Bloom filter 1.链接MapReduce作业 [顺序链接MapReduce作业] mapreduce-1 | mapr ...
- Akka.NET v1.0 已发布,支持Mono
Akka.NET 是Java/Scala 流行框架Akka的一个 .NET 开源移植.可用于构建高并发,分布式和容错事件驱动的应用在 .NET 和 Mono 平台之上.Akka.NET 经过一年多的努 ...
- SAE+WordPress快速搭建个人博客
前些天一时冲动,买了个域名,我想总不能放着不用吧,干脆就搭建了一个个人博客.下面我把搭建的过程分享给大家.注意,此文并不是攻略,只是为了记录下这个从无到有的过程,当然,假如解决了你的疑惑,那当然是极好 ...
- 分布式理论之一:Paxos算法的通俗理解
维基的简介:Paxos算法是莱斯利·兰伯特(Leslie Lamport,就是 LaTeX 中的"La",此人现在在微软研究院)于1990年提出的一种基于消息传递且具有高度容错特性 ...
- Application Request Route实现IIS Server Farms集群负载详解
序言 随着公司业务的发展,后台业务就变的越来越多,然而服务器的故障又像月经一样,时不时的汹涌而至,让我们防不胜防.那么后台的高可用,以及服务器的处理能力就要做一个横向扩展的方案,以使后台业务持续的稳定 ...
- FTP的搭建与虚拟目录作用<之简单讲解>
操作系统:win7 VS2010编写WebService与在IIS的发布<之简单讲解>中我已经说了IIS安装与使用,不明白的可以跳过去看. 1.添加FTP站点 2. 3. 4. 5. zq ...
- 窥探Vue.js 2.0
title: 窥探Vue.js2.0 date: 2016-09-27 10:22:34 tags: vue category: 技术总结 --- 窥探Vue.js2.0 令人兴奋的Vue.js 2. ...
- MVC5 网站开发之六 管理员 2、添加、删除、重置密码、修改密码、列表浏览
目录 奔跑吧,代码小哥! MVC5网站开发之一 总体概述 MVC5 网站开发之二 创建项目 MVC5 网站开发之三 数据存储层功能实现 MVC5 网站开发之四 业务逻辑层的架构和基本功能 MVC5 网 ...
- 3.C#面向对象基础聊天机器人
基于控制台的简单版的聊天机器人,词库可以自己添加. 聊天机器人1.0版本 源码如下: using System; using System.Collections.Generic; using Sys ...
- TFS2017持续集成构建
TFS2017发布已经有几个月了,经过了几天的部署和尝试,TFS2017的功能变化真是挺大的.特别是在构建方面的变化,在产品的向导中已经声明XAML版本控制器和代理已经弃用了,并建议升级原来13和15 ...