麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jQuery多個版本和其他js庫沖突的解決方法

2019-11-20 09:15:36
字體:
來源:轉載
供稿:網友

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(){ //使用jQueryjQuery("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.jsjQuery(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本身就是區分大小寫的。

以上所述是小編給大家介紹的jQuery多個版本和其他js庫沖突的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产成人精品二区 | 国产精品一区在线观看 | 成人免费观看49www在线观看 | 黄色片在线播放 | 欧美亚洲国产一区二区三区 | 精品一区二区三区免费视频 | 色综合欧美 | 久久精品小短片 | 97久久曰曰久久久 | 护士hd欧美free性xxxx | 精品三级内地国产在线观看 | 久久国产秒 | 久久久久久亚洲国产精品 | 欧美一级黄色录相 | 久久亚洲一区二区三区成人国产 | 日本成人一区二区 | 爱视频福利 | 香蕉视频网站在线观看 | 天天操综 | 久久性生活免费视频 | 中文日韩 | 中文字幕在线视频网站 | 高清一区二区在线观看 | 电影一级毛片 | 91一级毛片 | 亚洲视色 | 亚洲精品欧美二区三区中文字幕 | 毛片在线视频免费观看 | 日本成人一二三区 | 国产精品色综合 | 最新欧美精品一区二区三区 | 成人免费视频 | 国产高清一区 | 亚洲小视频在线观看,com | 干色视频 | 成熟女人特级毛片www免费 | 182tv成人福利视频免费看 | 91懂色| 国产人成精品综合欧美成人 | 久草视频福利在线观看 | 欧美成年私人网站 |