jquery判斷瀏覽器類型的代碼
更新時間:2012年11月05日 17:10:03 作者:
用jquery來判斷瀏覽器類型,如果只是僅僅為了判斷瀏覽器的類型而使用該方法,那么不建議使用,只是在你已經(jīng)使用了jquery才建議使用,因為沒必要因為這么小的一個功能就加載那么大的類庫吧
Jquery中利用navigator.userAgent.indexOf來判斷瀏覽器類型,并進行了一下處理,建議學習Jquery的朋友學習下,了解一下思路。
主要使用的方法:$.browser.['瀏覽器關(guān)鍵字']
$(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判斷瀏覽器的種類和版本.
version---瀏覽器版本
msie----ie瀏覽器(Microsoft Internet Explorer)
mozilla-火狐瀏覽器
opera--opera瀏覽器
如果我們要來判斷當前瀏覽器是否是IE6應該如何來判斷?
if($.browser.msie&&($.browser.version == "6.0")&&!$.support.style){
alert("ie6");
}
同樣Jquery判斷瀏覽器是否為IE7
if($.browser.msie&&($.browser.version == "7.0")){
alert("ie7");
}
如果不想使用Jquery,稍為修改下代碼就可以為自己所用Js代碼:
var userAgent = navigator.userAgent.toLowerCase();
browser={
version: (userAgent.match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [0,'0'])[1],
safari: /webkit/.test( userAgent ),
opera: /opera/.test( userAgent ),
msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ),
mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent )
}
調(diào)用的時候和jquery一樣,只不過把$符號取掉就行了
如果是為了判斷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的使用方法了
主要使用的方法:$.browser.['瀏覽器關(guān)鍵字']
復制代碼 代碼如下:
$(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判斷瀏覽器的種類和版本.
version---瀏覽器版本
msie----ie瀏覽器(Microsoft Internet Explorer)
mozilla-火狐瀏覽器
opera--opera瀏覽器
如果我們要來判斷當前瀏覽器是否是IE6應該如何來判斷?
復制代碼 代碼如下:
if($.browser.msie&&($.browser.version == "6.0")&&!$.support.style){
alert("ie6");
}
同樣Jquery判斷瀏覽器是否為IE7
復制代碼 代碼如下:
if($.browser.msie&&($.browser.version == "7.0")){
alert("ie7");
}
如果不想使用Jquery,稍為修改下代碼就可以為自己所用Js代碼:
復制代碼 代碼如下:
var userAgent = navigator.userAgent.toLowerCase();
browser={
version: (userAgent.match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [0,'0'])[1],
safari: /webkit/.test( userAgent ),
opera: /opera/.test( userAgent ),
msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ),
mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent )
}
調(diào)用的時候和jquery一樣,只不過把$符號取掉就行了
如果是為了判斷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的使用方法了
相關(guān)文章
關(guān)于jQuery.ajax()的jsonp碰上post詳解
這篇文章主要介紹了關(guān)于jQuery.ajax()的jsonp碰上post的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-07-07
jQuery監(jiān)聽文件上傳實現(xiàn)進度條效果的方法
下面小編就為大家?guī)硪黄猨Query監(jiān)聽文件上傳實現(xiàn)進度條效果的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
jquery設置text的值示例(設置文本框 DIV 表單值)
本文主要介紹了jquery設置內(nèi)容的方法,下面的例子演示如何通過 text()、html()以及val()方法來設置內(nèi)容,大家參考使用吧2014-01-01

