解決jQuery多個版本,與其他js庫衝突方法
阿新 • • 發佈:2019-01-09
jQuery多個版本或和其他js庫衝突主要是常用的$符號的問題,這個問題 jquery早早就有給我們預留處理方法了,下面一起來看看解決辦法。
1.同一頁面jQuery多個版本或衝突解決方法。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <title>jQuery測試頁</title> </head> <body> <!-- 引入1.6.4版的jq --> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.js"></script> <script> var jq164 = jQuery.noConflict(true); </script> <!-- 引入1.4.2版的jq --> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.js"></script> <script> var jq142 = jQuery.noConflict(true); </script> <script> (function($){//此時的$是jQuery-1.6.4 $('#'); })(jq164); </script> <script> jq142(function($){ //此時的$是jQuery-1.4.2 $('#'); }); </script> </body> </html>
2.同一頁面jQuery和其他js庫衝突解決方法
jQuery noConflict() 方法
noConflict() 方法會釋放會 $ 識別符號的控制,這樣其他指令碼就可以使用它了。
jquery.js在prototype.js之前進行引入,如:
<script src="jquery.js" type="text/javascript"></script> <script src="prototype.js" type="text/javascript"></script> <p id="pp">test---prototype</p> <p>test---jQuery</p>
2.1 當然,您仍然可以通過全名替代簡寫的方式來使用 jQuery:
<script type="text/javascript"> jQuery.noConflict(); //將變數$的控制權讓渡給prototype.js,全名可以不呼叫。 jQuery(function(){ //使用jQuery jQuery("p").click(function(){ alert( jQuery(this).text() ); }); }); //此處不可以再寫成$,此時的$代表prototype.js中定義的$符號。 $("pp").style.display = 'none'; //使用prototype </script>
2.2 您也可以建立自己的簡寫。noConflict() 可返回對 jQuery 的引用,您可以把它存入變數,以供稍後使用。請看這個例子:
<script type="text/javascript"> var $j = jQuery.noConflict(); //自定義一個比較短快捷方式 $j(function(){ //使用jQuery $j("p").click(function(){ alert( $j(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype </script>
2.3 如果你的 jQuery 程式碼塊使用 簡寫,並且您不願意改變這個快捷方式,那麼您可以把簡寫,並且您不願意改變這個快捷方式,那麼您可以把 符號作為變數傳遞給 ready 方法。這樣就可以在函式內使用 $ 符號了 - 而在函式外,依舊不得不使用 "jQuery":
<script type="text/javascript"> jQuery.noConflict(); //將變數$的控制權讓渡給prototype.js jQuery(document).ready(function($){ $("p").click(function(){ //繼續使用 $ 方法 alert( $(this).text() ); }); }); jQuery(function($){ //使用jQuery $("p").click(function(){ //繼續使用 $ 方法 alert( $(this).text() ); }); }); </script>
2.4 使用語句塊:
<script type="text/javascript"> jQuery.noConflict(); //將變數$的控制權讓渡給prototype.js (function($){ //定義匿名函式並設定形參為$ $(function(){ //匿名函式內部的$均為jQuery $("p").click(function(){ //繼續使用 $ 方法 alert($(this).text()); }); }); })(jQuery); //執行匿名函式且傳遞實參jQuery $("pp").style.display = 'none'; //使用prototype </script>
這種使用語句塊的方法非常有用,在我們自己寫jquery外掛時,應該都使用這種寫法,因為我們不知道具體工作過程中是如何順序引入各種js庫的,而這種語句塊的寫法卻能遮蔽衝突。
注意:
1.引用javascript類庫時,把jQuery引用放在最後面,可以避免衝突。
2.特別要注意jQuery()代替$()時,jQuery是區分大小寫的,因為javascript本身就是區分大小寫的。