zl程序教程

您现在的位置是:首页 >  前端

当前栏目

jQuery下通过$.browser来判断浏览器.

jQuery浏览器 通过 判断 Browser
2023-06-13 09:14:27 时间
使用方法:
$.browser.["浏览器关键字"]
复制代码代码如下:

$(function(){
if($.browser.msie){
alert("thisismsie");
}
elseif($.browser.safari)
{
alert("thisissafari!");
}
elseif($.browser.mozilla)
{
alert("thisismozilla!");
}
elseif($.browser.opera){
alert("thisisopera");
}
else{
alert("idon"tkonw!");
}

我们看下jQuery的源码:
复制代码代码如下:

varuserAgent=navigator.userAgent.toLowerCase();
//Figureoutwhatbrowserisbeingused
jQuery.browser={
version:(userAgent.match(/.+(?:rv|it|ra|ie)[\/:]([\d.]+)/)||[])[1],
safari:/webkit/.test(userAgent),
opera:/opera/.test(userAgent),
msie:/msie/.test(userAgent)&&!/opera/.test(userAgent),
mozilla:/mozilla/.test(userAgent)&&!/(compatible|webkit)/.test(userAgent)
};

jQuery使用的是通过正则来匹配userAgent判断浏览器的种类和版本.
如果我们要来判断当前浏览器是否是IE6应该如何来判断?
$.browser.msie&&($.browser.version=="6.0")&&!$.support.style
同样jQuery判断浏览器是否为IE7
$.browser.msie&&($.browser.version=="7.0")
如果不考虑向后兼容性,又不想为了判断各浏览器类型而导入jQuery
判断IE最简单的方法是
复制代码代码如下:
if(document.all){
alert("IE6")
}

$.browser是通过正则表达式来匹配userAgent来判断浏览器版本和种类的.jquery1.3.2版本的文档中已经声明jquery.browser及jquery.browser.version建议弃用,可以使用jquery.support来代替
但是目前的情况来看,jquery.support并不好用,而且是非常的难用,我们还是老老实实的用$.browser来判断浏览器类型吧
如果是为了判断IE的版本我还是推荐用IE的条件表达式来书写JS
复制代码代码如下:
<!--[ifIE]>
<scripttype="text/javascript">
alert("ie")
</script>
<![endif]-->
<!--[ifIE6]>
<scripttype="text/javascript">
alert("ie6")
</script>
<![endif]-->
<!--[ifIE7]>
<scripttype="text/javascript">
alert("ie7")
</script>
<![endif]-->

这个比我们手动通过$.browser来判断IE版本更精准,也不用去记jquery的browser的使用方法了