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