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

一、使用方法 

语法:$.browser.["浏览器关键字"]

 

$(function() { 
if($.browser.msie) { 
alert("this is IE"); 
} 
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的条件表达式也可以书写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的使用方法了。


原帖地址:http://www.poluoluo.com/jzxy/201110/145284.html

 

 

jquery 1.9 之后已经删除判断浏览器版本的方法

 

二、解决方法:

 http://www.cnblogs.com/webqiand/p/6624752.html

posted @ 2014-07-24 18:26  webnote  阅读(315)  评论(0编辑  收藏  举报