jQuery 1.9使用$.support替代$.browser的使用方法
jQuery从1.9版开始,移除了$.browser和$.browser.version,取而代之的是$.support。在更新的2.0版本中,将不再支持IE6/7/8。以后,如果用户需要支持IE6/7/8,只能使用jQuery1.9。如果要全面支持IE,并混合使用jQuery1.9和2.0,官方的解决方案是:
<!--[ifltIE9]> <scriptsrc='jquery-1.9.0.js'></script> <![endif]--> <!--[ifgteIE9]> <scriptsrc='jquery-2.0.0.js'></script> <![endif]-->
从长久来看,这样有利于在复杂情况下根据浏览器特性进行分别处理,而不是简单的检测浏览器类型和版本。但目前很多旧程序的移植恐怕无法直接过渡为根据浏览器支持特性,所以在网上找了一些能够直接替换的解决办法。
判断浏览器类型:
$.browser.mozilla=/firefox/.test(navigator.userAgent.toLowerCase()); $.browser.webkit=/webkit/.test(navigator.userAgent.toLowerCase()); $.browser.opera=/opera/.test(navigator.userAgent.toLowerCase()); $.browser.msie=/msie/.test(navigator.userAgent.toLowerCase());
等号后面的表达式返回的就是true/false,可以直接用来替换原来的$.browser.msie等。如需要检查是否为IE6时,可以这么写:
//Old if($.browser.msie&&7>$.browser.version){} //New if('undefined'==typeof(document.body.style.maxHeight)){}
检查是否为IE6-8:
if(!$.support.leadingWhitespace){}
终极方法是用另外的类库替代,可以参照老外写的一篇文章:
Browserdetect