使用JQuery 區分判斷 不一樣內核的瀏覽器

使用方法: 
$.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的使用方法了
相關文章
相關標籤/搜索