[jQuery] Cannot read property ‘msie’ of undefined錯誤的解決方法

[jQuery] Cannot read property ‘msie’ of undefined錯誤的解決方法
最近把一個項目的jQuery升級到最新版,發現有些頁面報錯Cannot read property ‘msie’ of undefined。上jQuery網站上搜了一下,原因是$.browser這個api從jQuery1.9開始就正式廢除,js代碼裏只要用到$.browser就會報這個錯。具體說明參見jQuery官方說明。
擼主順便擴展閱讀了一下,發現jQuery 1.9把所有在之前版本里標記爲deprecated的api都正式刪除了,徹底不再向後兼容。對於升級到最新jQuery的童鞋而言,這意味着得花費一些額外的時間把代碼升級使用新的api,或者自己另外實現這些被刪除的方法。幸運的是,jQuery團隊考慮到了這個改動帶來的不便,推出了一個插件jQuery Migrate,這個插件能夠自動恢復那些在最新版本里之後被廢棄的API,從而讓已有的js代碼無須改動就能和最新的jQuery庫一起正常運行。
下面是具體的解決方法,先下載最新的jQuery Migrate插件,然後在引用jQuery js的地方之後加上一行對jQuery Migrate js文件的引用即可。
<script src="http://code.jquery.com/jquery-1.10.2.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.2.1.js"></script>

對於不喜歡用jQuery Migrate的童鞋,可以嘗試下面另外一種方法,加載順序爲,在jQuery文件之後,$.browser的代碼之前。

jQuery.browser={};(function(){jQuery.browser.msie=false; jQuery.browser.version=0;if(navigator.userAgent.match(/MSIE ([0-9]+)./)){ jQuery.browser.msie=true;jQuery.browser.version=RegExp.$1;}})();


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章