亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

關于jQuery庫沖突的完美解決辦法

2019-11-19 16:32:34
字體:
來源:轉載
供稿:網友

前言

一次面試中面試官問到jQuery和別的庫沖突怎么解決?雖然以前看過,但是我已經不記得了。

我的思路就是如果讓我來設計,那我就用一個默認值$,不傳參數,那就用$,最后就掛載在window.$上,傳參數就用傳入名字,比如傳入jq,那我就掛載在window.jq上。

var myControl="jq";(function(name){ var $=name ||"$"; //name存在$的值就是name的值,不存在或為null,$的值為字符串"$" console.log($); window[$]=function(){ alert("123"); }})(myControl)window[myControl]();

事實上這肯定不是jquery解決沖突的辦法了。那就看看jQuery怎么解決沖突吧。

jQuery多個版本或和其他js庫沖突主要是常用的$符號的沖突。

一、沖突的解決

1、同一頁面jQuery多個版本沖突解決方法

<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>

2、jQuery庫在其他庫之后導入

jQuery noConflict() 方法會釋放會 $ 標識符的控制,這樣其他腳本就可以使用它了。

1、可以通過jQuery全名替代簡寫的方式來使用 jQuery

在其他庫和jQuery庫都加載完畢后,可以在任何時候調用jQuery.noConflict()函數來將變量$的控制權移交給其他JavaSript庫。然后就可以在程序里將jQuery()函數作為jQuery對象的制造工廠。

<script src="prototype.js" type="text/javascript"></script><script src="jquery.js" type="text/javascript"></script><p id="pp">test---prototype</p><p>test---jQuery</p><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、自定義一個快捷方式

noConflict() 可返回對 jQuery 的引用,可以把它存入自定義名稱,例如jq,$J變量,以供稍后使用。

這樣可以確保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>

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>

或者使用IEF語句塊,這應該是最理想的方式,因為可以通過改變最少的代碼來實現全面的兼容性。

在我們自己寫jquery插件時,應該都使用這種寫法,因為我們不知道具體工作過程中是如何順序引入各種js庫的,而這種語句塊的寫法卻能屏蔽沖突。

<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>

3、jQuery庫在其他庫之前導入

jQuery庫在其他庫之前導入,$的歸屬權默認歸后面的JavaScript庫所有。那么可以直接使用"jQuery"來做一些jQuery的工作。

同時,可以使用$()方法作為其他庫的快捷方式。這里無須調用jQuery.noConflict()函數。

<!-- 引入 jQuery --><script src="../../scripts/jquery.js" type="text/javascript"></script><!-- 引入 prototype --><script src="lib/prototype.js" type="text/javascript"></script><body><p id="pp">Test-prototype(將被隱藏)</p><p >Test-jQuery(將被綁定單擊事件)</p><script type="text/javascript">jQuery(function(){ //直接使用 jQuery ,沒有必要調用"jQuery.noConflict()"函數。 jQuery("p").click(function(){    alert( jQuery(this).text() ); });});$("pp").style.display = 'none'; //使用prototype</script></body>

二、原理

1、源碼

源碼:看一下源碼里怎么做到的

var// Map over jQuery in case of overwrite_jQuery = window.jQuery,// Map over the $ in case of overwrite_$ = window.$,jQuery.extend({ noConflict: function( deep ) {   if ( window.$ === jQuery ) {    window.$ = _$;   }   if ( deep && window.jQuery === jQuery ) {    window.jQuery = _jQuery;   }   return jQuery;  }});

在jQuery加載的時候,通過事先聲明的_jQuery變量獲取到當前window.jQuery,通過_$獲取到當前window.$

通過jQuery.extend()把noConflict掛載到jQuery下面。所以我們在調用的時候都是jQuery.noConflict()這樣調。

在調用noConflict()時做了2個判斷,

第一個if,把$的控制權交出去。

第二個if,在noConflict()傳參的時候把,jQuery的控制權交出去。

最后noConflict()返回jQuery對象,用哪個參數接收,哪個參數將擁有jQuery的控制權。

2、 驗證

//沖突  var $ = 123; //假設其他庫中$為123 $(   function () {    console.log($); //報錯Uncaught TypeError: $ is not a function   } );

解決沖突

//解決沖突 var jq = $.noConflict(); var $ = 123; jq(function () {  alert($); //123 });

釋放$控制權例子

<script> var $ = 123; // window.$是123,存儲在私有的_$上。</script><script src="https://code.jquery.com/jquery-2.2.4.js"></script><body><div>aaa</div><script> var jq = $.noConflict();//當window.$===jQuery的時候,把_$賦給了window.$。 jq(function () {  alert($); //123 });</script>

釋放jQuery控制權例子

參數deep的作用:deep用來放棄jQuery對外的接口。

 如下,noConflict()不寫參數,彈出jQuery為構造函數。

<script> var $ = 123; var jQuery=456;</script><script src="https://code.jquery.com/jquery-2.0.3.js"></script><body><div>aaa</div><script> var jq = $.noConflict(); jq(function () {  alert(jQuery); //構造函數 });</script>


如果寫個參數true,會彈出456。

<script> var $ = 123; var jQuery=456;</script><script src="https://code.jquery.com/jquery-2.0.3.js"></script><body><div>aaa</div><script> var jq = $.noConflict(true); //寫了true或者參數的時候,deep為真window.jQuery===jQuery為真,所以進入if條件。把456賦值給window.jQuery jq(function () {  alert(jQuery); //456 });</script>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲v日韩v综合v精品v| 韩国三级日本三级少妇99| 亚洲欧美日韩久久久久久| 久久国产精品久久久| 日韩av手机在线看| 在线一区二区日韩| www国产91| 亚洲精品www久久久| 欧美在线视频在线播放完整版免费观看| 亚洲精品日韩激情在线电影| 色综合五月天导航| 国产精品久久久久久久久久久久久久| 成人网在线观看| 日韩有码在线视频| 欧美日韩国产色视频| 美女久久久久久久| 欧美精品18videosex性欧美| 日韩在线视频观看| 欧美日韩亚洲视频一区| 久久久久亚洲精品国产| 精品激情国产视频| 国产成人精品久久久| 亚洲第一页自拍| 91久久精品国产91久久性色| 色综合91久久精品中文字幕| 亚洲欧美一区二区三区久久| 国产婷婷成人久久av免费高清| xxx成人少妇69| 亚洲大胆人体av| 色综合色综合网色综合| 国产综合视频在线观看| 亚洲色图欧美制服丝袜另类第一页| 91亚洲精品一区| 欧美成人午夜视频| 亚洲精品v欧美精品v日韩精品| 欧美巨乳美女视频| 国产成人精品午夜| 欧美成人免费大片| 亚洲精品xxx| 国产欧美日韩亚洲精品| 国产精品无av码在线观看| 在线看片第一页欧美| 日韩欧美亚洲范冰冰与中字| 日韩av电影手机在线观看| 国产精品在线看| 久久久久久香蕉网| 一级做a爰片久久毛片美女图片| 91成人福利在线| 国产成一区二区| 国产美女精品免费电影| 国产91精品久久久| 午夜精品久久久久久久久久久久| 日韩av免费网站| 亚洲爱爱爱爱爱| 欧美精品在线视频观看| 日本在线观看天堂男亚洲| 欧美激情欧美激情| 成人在线精品视频| 国产精品久久一| 久久人人爽人人爽人人片av高清| 人人澡人人澡人人看欧美| 欧美精品久久久久久久| 欧美电影第一页| 色琪琪综合男人的天堂aⅴ视频| 欧美激情图片区| 96精品久久久久中文字幕| 在线视频日本亚洲性| 欧美激情中文字幕乱码免费| 久久99精品久久久久久噜噜| 91av在线影院| 欧美美最猛性xxxxxx| 国产亚洲精品一区二555| 欧美色欧美亚洲高清在线视频| 国产视频亚洲视频| 亚洲成人性视频| 日韩一级裸体免费视频| 亚洲第一av在线| 97在线免费观看| 欧美丰满片xxx777| 国产精品久久久精品| 亚洲国产一区二区三区在线观看| 日本亚洲欧洲色| 亚洲精品av在线| 欧美成人网在线| 成人网在线观看| 亚洲精品成人久久电影| 插插插亚洲综合网| 欧美老女人xx| 日韩午夜在线视频| 欧美日韩性生活视频| 国产精品视频1区| 最好看的2019的中文字幕视频| 午夜精品视频在线| 不卡av在线播放| 国产啪精品视频网站| 亚洲福利在线播放| 另类专区欧美制服同性| 国产成人精品免高潮在线观看| 亚洲精品xxx| 久久精品99久久久久久久久| 日韩网站在线观看| 亚洲国产成人久久综合| 午夜精品久久久久久99热软件| 韩剧1988在线观看免费完整版| 亚洲精品久久久久久下一站| 不卡av在线网站| 国产欧美日韩丝袜精品一区| 国产精品直播网红| 欧美黑人极品猛少妇色xxxxx| 亚洲精品www久久久久久广东| 日韩精品有码在线观看| 欧美激情久久久| 国产成人精品999| 一本色道久久综合亚洲精品小说| 午夜精品久久久久久99热| 亚洲黄色av网站| 欧美性理论片在线观看片免费| 国产欧美中文字幕| 欧美视频国产精品| 亚洲欧洲激情在线| www.亚洲男人天堂| 亚洲伊人第一页| 韩国国内大量揄拍精品视频| 亚洲乱码一区二区| 亚洲成av人影院在线观看| 亚洲自拍偷拍在线| 日韩精品极品在线观看播放免费视频| 国产在线视频91| 精品爽片免费看久久| 国产精品久久久久久久午夜| 亚洲精品白浆高清久久久久久| 欧美成人在线网站| 亚洲自拍小视频免费观看| 亚洲嫩模很污视频| 4438全国亚洲精品在线观看视频| 亚洲男人天堂九九视频| 美女福利视频一区| 国产日韩欧美电影在线观看| 日韩一区二区三区在线播放| 91久久在线视频| 国产精品日韩在线播放| 这里只有精品丝袜| 久久精品免费播放| 日本欧美中文字幕| 亚洲色图校园春色| 国产免费久久av| 精品日韩视频在线观看| 国产成人一区二| 欧美激情xxxx性bbbb| 91大神福利视频在线| 亚洲欧美国产va在线影院| 亚洲成人激情在线观看| 欧美成人四级hd版| 国产亚洲一级高清| 亚洲国产精品悠悠久久琪琪| 亚洲国产日韩欧美在线99| 日韩精品中文在线观看| 九九热r在线视频精品| 这里只有精品在线播放| 国产精品久久久久久久久久东京| 日本高清久久天堂| 91成人国产在线观看| 超碰91人人草人人干| 亚洲日本成人网|