javascript 学习笔记(六)浏览器类型及版本信息检测代码
javascript 学习笔记(六)浏览器类型及版本信息检测代码
发布时间:2016-12-30 来源:查字典编辑
摘要:下面的checkBrowser()函数主要检测了三种浏览器(IE,firefox,chrome),其它的浏览器的检测有兴趣的朋友可以自行添加...

下面的checkBrowser()函数主要检测了三种浏览器(IE, firefox, chrome),其它的浏览器的检测有兴趣的朋友可以自行添加检测代码!

HTML部分代码: (页面加载时执行检测函数)

复制代码 代码如下:

<body onload="checkBrowser()">

<p id="userAgent"></p>

<p id="browser"></p>

</body>

javascript部分代码:

检测的原理主要根据 浏览器的用户代理报头nanigator.userAgent中提取到浏览器和类型及版本信息,利用正则表达式可以很容易的满足我们的需求,如对正则表达式不熟悉,可参照此文(正则表达式)

复制代码 代码如下:

function check(reg) {

var ug = navigator.userAgent.toLowerCase();

return reg.test(ug);

}

function checkBrowser() {

var ug = navigator.userAgent.toLowerCase();

var userAgent = document.getElementById("userAgent");

userAgent.innerHTML = "浏览器的用户代理报头:" + ug;

var browserType = "";

var ver = "";

//检测IE及版本

var IE = ug.match(/msies*d.d/); //提取浏览器类型及版本信息,注match()方法返回的是数组而不是字符串

var isIE = check(/msie/);

if(isIE) {

browserType = "Internet Explorer";

ver = IE.join(" ").match(/[0-9]/g).join("."); //先用join()方法转化为字符串,然后用match()方法匹配到版本信息,再用join()方法转化为字符串

}

//检测chrome及版本

var chrome = ug.match(/chrome/d.d/gi);

var isChrome = check(/chrome/);

if(isChrome) {

browserType = "Chrome";

ver = chrome.join(" ").match(/[0-9]/g).join(".");

}

//检测firefox及版本

var firefox = ug.match(/firefox/d.d/gi);

var isFirefox = check(/firefox/);

if(isFirefox) {

browserType = "Firefox";

ver = firefox.join(" ").match(/[0-9]/g).join(".");

}

var browser = document.getElementById("browser");

browser.innerHTML = "您正在使用的浏览器为:" + browserType + "<span>版本为:</span>" + ver;

}

PS:各浏览器的用户代理信息如下:

IE:Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; InfoPath.3; BOIE9;ZHCN);
firefox:Mozilla/5.0 (Windows NT 6.1; rv:2.0) Gecko/20100101 Firefox/4.0;
chrome:Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.13 (KHTML, like Gecko) Chrome/9.0.597.98 Safari/534.13

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类