如何解決jQuery 和其他JS庫的沖突
在 jQuery 庫中,幾乎所有的插件都被限制在它的命名空間里。通常,全局對象都被很好地存儲在 jQuery 命名空間里,因此當(dāng)把 jQuery 和其他 JavaScript 庫(例如 Prototype、MooTools 或 YUI)一起使用時(shí),不會引起沖突。
注意:默認(rèn)情況下,jQuery 用 $ 作為自身的快捷方式。
1.jQuery庫在其他庫之后導(dǎo)入
在其他庫和 jQuery 庫都被加載完畢后,可以在任何時(shí)候調(diào)用 jQuery.noConflict() 函數(shù)來將變量 $ 的控制權(quán)移交給其他 JavaScript 庫。示例如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>沖突解決1</title> <!-- 引入 prototype --> <script src="lib/prototype.js" type="text/javascript"></script> <!-- 引入 jQuery --> <script src="../../scripts/jquery.js" type="text/javascript"></script> </head> <body> <p id="pp">Test-prototype(將被隱藏)</p> <p >Test-jQuery(將被綁定單擊事件)</p> <script type="text/javascript"> jQuery.noConflict(); //將變量$的控制權(quán)讓渡給prototype.js jQuery(function(){ //使用jQuery jQuery("p").click(function(){ alert( jQuery(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype.js隱藏元素 </script> </body> </html>
然后,就可以在程序里將 jQuery() 函數(shù)作為 jQuery 對象的制造工廠。
此外,還有另一種選擇。如果想確保 jQuery 不會與其他庫沖突,但又想自定義一個(gè)快捷方式,可以進(jìn)行如下操作:
<script type="text/javascript"> var $j = jQuery.noConflict(); //自定義一個(gè)比較短快捷方式 $j(function(){ //使用jQuery $j("p").click(function(){ alert( $j(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype.js隱藏元素 </script>
可以自定義備用名稱,例如 jq、$J、awesomequery 等。
如果不想給 jQuery 自定義這些備用名稱,還想使用 $ 而不管其他庫的 $() 方法,同時(shí)又不想與其他庫相沖突,那么可以使用以下兩種解決方法。
其一:
<script type="text/javascript"> jQuery.noConflict(); //將變量$的控制權(quán)讓渡給prototype.js jQuery(function($){ //使用jQuery $("p").click(function(){ //繼續(xù)使用 $ 方法 alert( $(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype </script>
其二:
<script type="text/javascript"> jQuery.noConflict(); //將變量$的控制權(quán)讓渡給prototype.js (function($){ //定義匿名函數(shù)并設(shè)置形參為$ $(function(){ //匿名函數(shù)內(nèi)部的$均為jQuery $("p").click(function(){ //繼續(xù)使用 $ 方法 alert($(this).text()); }); }); })(jQuery); //執(zhí)行匿名函數(shù)且傳遞實(shí)參jQuery $("pp").style.display = 'none'; //使用prototype </script>
這應(yīng)該是最理想的方式,因?yàn)榭梢酝ㄟ^改變最少的代碼來實(shí)現(xiàn)全面的兼容性。
2.jQuery庫在其他庫之前導(dǎo)入
如果 jQuery 庫在其他庫之前就導(dǎo)入了,那么可以直接使用"jQuery”來做一些jQuery的工作。同時(shí),可以使用 $() 方法作為其他庫的快捷方式。這里無需調(diào)用 jQuery.noconflict() 函數(shù)。示例如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>沖突解決5</title> <!-- 引入 jQuery --> <script src="../../scripts/jquery.js" type="text/javascript"></script> <!-- 引入 prototype --> <script src="lib/prototype.js" type="text/javascript"></script> </head> <body> <p id="pp">Test-prototype(將被隱藏)</p> <p >Test-jQuery(將被綁定單擊事件)</p> <script type="text/javascript"> jQuery(function(){ //直接使用 jQuery ,沒有必要調(diào)用"jQuery.noConflict()"函數(shù)。 jQuery("p").click(function(){ alert( jQuery(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype </script> </body> </html>
有了這些方法來解決沖突,就可以在項(xiàng)目中放心地引用 jQuery 了。
以上就是如何解決jQuery 和其他JS庫的沖突的詳細(xì)內(nèi)容,更多關(guān)于解決jQuery JS庫沖突的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Jquery高級應(yīng)用Deferred對象原理及使用實(shí)例
這篇文章主要介紹了Jquery高級應(yīng)用Deferred對象原理及使用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05JQuery統(tǒng)計(jì)input和textarea文字輸入數(shù)量(代碼分享)
本文主要介紹了jQuery實(shí)現(xiàn)統(tǒng)計(jì)輸入文字個(gè)數(shù)的方法,具有一定的參考價(jià)值,需要的朋友一起來看下吧2016-12-12深入理解jQuery.data() 的實(shí)現(xiàn)方式
本篇文章主要介紹了jQuery.data() 的實(shí)現(xiàn)方式,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11jQuery中filter(),not(),split()使用方法
jQuery下一些查找過濾功能filter(),not(),split()用法,可以讓jquery更容易的操作控制頁面元素。2010-07-07jquery捕捉回車鍵及獲取checkbox值與異步請求的方法
這篇文章主要介紹了jquery捕捉回車鍵及獲取checkbox值與異步請求的方法,實(shí)例分析了jQuery針對回車鍵的捕捉,checkbox值的獲取以及異步請求的響應(yīng)等相關(guān)技巧,需要的朋友可以參考下2015-12-12