jQuery $.browser 判断浏览器的方法

发布时间:2020-05-04编辑:脚本学堂
本文介绍下,jquery判断浏览器的类型的方法,使用$.browser工具类来判断浏览器的类型,有需要的朋友参考下吧。

使用方法:
$.browser.['浏览器关键字']

例子:
 

复制代码 代码示例:
$(function() {
if($.browser.msie) {
alert("this is msie");
}
else if($.browser.safari)
{
alert("this is safari!");
}
else if($.browser.mozilla)
{
alert("this is mozilla!");
}
else if($.browser.opera) {
alert("this is opera");
}
else {
alert("i don't konw!");
}

jquery源码分析:
 

复制代码 代码示例:
var userAgent = navigator.userAgent.toLowerCase();
// Figure out what browser is being used
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。
例如:
 

复制代码 代码示例:
<!--[if IE]>
<script type="text/javascript">
alert("ie")
</script>
<![endif]-->
<!--[if IE 6]>
<script type="text/javascript">
alert("ie6")
</script>
<![endif]-->
<!--[if IE 7]>
<script type="text/javascript">
alert("ie7")
</script>
<![endif]-->
 

以上方法比使用$.browser来判断IE版本更精准,而且不用记jquery的browser的使用方法,是不是更好呢?!