溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

不同的jquery版本沖突的解決方法

發(fā)布時間:2020-11-24 13:52:58 來源:億速云 閱讀:135 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細講解有關不同的jquery版本沖突的解決方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

不同的jquery版本沖突的解決方法:首先在【1.4.2】的源代碼的最后加相關代碼;然后在基于【1.4.2】的框架的所有插件的頭部加上相關代碼;最后要用基于【jQuery1.4.2】的選取函數(shù)就用【$j4(element)】。

不同的jquery版本沖突的解決方法:

案例:解決jQuery1.3.2和1.4.2的沖突。

第一步:在1.4.2的源代碼的最后加上一句 :

var $j4 = jQuery.noConflict(true);

之所以在源碼這里加,而不是像大多數(shù)文章提的在要用到的時候加,這是因為很多基于1.4.2的插件都要加,在這里加可以避免過多插件加這句代碼導致重復。這一句是將1.4.2的jQuery和$的引用權限全部放棄。也就是基于1.4.2的插件不能再用jQuery和$了。同時給予$j4的新的命名空間,注意它是window的屬性???.4.2的源代碼會發(fā)現(xiàn)它其實也就執(zhí)行了這兩句:

window.$=_$;
window.jQuery=_jQuery;

道理同window.$=_temp$(返還命名空間)只是命名不同而已。

第二步:在基于1.4.2的框架的所有插件的頭部加上以下代碼:

var _temp$ = window.$,_tempjQuery = window.jQuery;

將jQuery1.3.2的$和jQuery放到臨時的變量空間上:

window.$ = $j4;

這句和下面的那句都是為了給中間的代碼能夠正確使用jQuery和$用的。后面的$j4是賦予他們正確的引用。

window.jQuery = $j4;

之所以要先放臨時變量存儲,有三點必須這樣做的理由:

①.我們不希望改動大量的jQuery插件源代碼,最好是不動,即使改的話,盡量改的少。而在頭部尾部加改動代碼,中間的原始代碼不動也是不錯的一種方式。

②.因為1.4.2的已經放棄了jQuery和$的控制權,但是已有的插件代碼又用了他們來做引用,因為插件不可能預知沖突,即使有沖突他人開發(fā)的插件也一定要用$或者jQuery引用,除非它不是jQuery下的插件。

③.為了防止插件里面直接用window.$window.jQuery進行引用從而導致引用到1.3.2的jQuery和$,雖然這種情況比較少,但是以防萬一。

中間的原始代碼不動,尾部加以下代碼:

window.$ = _temp$;//將$的引用權限返還給jQuery1.3.
window.jQuery = _tempjQuery;//將jQuery的引用權限返還給jQuery1.3.

第三步:以后要用基于jQuery1.4.2的選取函數(shù)就只能用$j4(element)了。

總結:到目前為止可行方案:jQuery1.4.2完全放棄$和jQuery的控制權限。1.3.2放棄$的控制權限但不放棄jQuery的權限,其實jQuery也可放棄,只不過要給個別名$j3。prototype最好放在jQuery1.3.2后面,它獲得$的控制權限。只是以后要用jQuery1.4.2就必須用$j4來引用了。但這樣即使有再多的jQuery框架版本沖突問題,也全部解決掉了。假如來了個1.2的jQuery怎么辦,參照(2)的執(zhí)行步驟,只不過第一步改為:

var $j2 = jQuery.noConflict(true);

第三步用$j2(element)罷了。道理都是相同的。

相信本文所述對大家的jQuery程序設計有一定的借鑒價值。

關于不同的jquery版本沖突的解決方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI