jQuery 1.9使用$.support替代$.browser的使用方法

NO IMAGE

jQuery 從 1.9 版開始,移除了 $.browser 和 $.browser.version , 取而代之的是 $.support 。 在更新的 2.0 版本中,將不再支援 IE 6/7/8。 以後,如果使用者需要支援 IE 6/7/8,只能使用 jQuery 1.9。 如果要全面支援 IE,並混合使用 jQuery 1.9 和 2.0, 官方的解決方案是:


<!--[if lt IE 9]>
<script src='jquery-1.9.0.js'></script>
<![endif]-->
<!--[if gte IE 9]>
<script src='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)) {} 

檢查是否為 IE 6-8:


if (!$.support.leadingWhitespace) {} 

終極方法是用另外的類庫替代,可以參照老外寫的一篇文章:

Browser detect

您可能感興趣的文章:

解決jquery外掛:TypeError:$.browser is undefined報錯的方法jQuery 1.9移除了$.browser可以使用$.support來替代jQuery下通過$.browser來判斷瀏覽器.JQuery下的Live方法和$.browser方法使用程式碼$.browser.msie 為空或不是物件問題的多種解決方法