關於解決jq不同版本相容性問題
用過jQuery的朋友都知道jQuery不同版本會引發衝突,本文就此問題提出有效的解決方案如下:
案例:解決jQuery1.3.2和1.4.2的衝突。(本例已測試通過!)
第一步:在1.4.2的原始碼的最後加上一句 :
1 |
var
$j4 = jQuery.noConflict( true );
|
之所以在原始碼這裡加,而不是像大多數文章提的在要用到的時候加,這是因為很多基於1.4.2的外掛都要加,在這裡加可以避免過多外掛加這句程式碼導致重複。這一句是將1.4.2的jQuery和$的引用許可權全部放棄。也就是基於1.4.2的外掛不能再用jQuery和$了。同時給予$j4的新的名稱空間,注意它是window的屬性。看1.4.2的原始碼會發現它其實也就執行了這兩句:
1 2 |
window.$=_$;
window.jQuery=_jQuery;
|
道理同window.$=_temp$(返還名稱空間)只是命名不同而已。
第二步:在基於1.4.2的框架的所有外掛的頭部加上以下程式碼:
1 |
var
_temp$ = window.$,_tempjQuery = window.jQuery;
|
將jQuery1.3.2的$和jQuery放到臨時的變數空間上:
?1 |
window.$
= $j4;
|
這句和下面的那句都是為了給中間的程式碼能夠正確使用jQuery和$用的。後面的$j4是賦予他們正確的引用。
1 |
window.jQuery
= $j4;
|
之所以要先放臨時變數儲存,有三點必須這樣做的理由:
①.我們不希望改動大量的jQuery外掛原始碼,最好是不動,即使改的話,儘量改的少。而在頭部尾部加改動程式碼,中間的原始程式碼不動也是不錯的一種方式。
②.因為1.4.2的已經放棄了jQuery和$的控制權,但是已有的外掛程式碼又用了他們來做引用,因為外掛不可能預知衝突,即使有衝突他人開發的外掛也一定要用$或者jQuery引用,除非它不是jQuery下的外掛。
③.為了防止外掛裡面直接用window.$和window.jQuery進行引用從而導致引用到1.3.2的jQuery和$,雖然這種情況比較少,但是以防萬一。
中間的原始程式碼不動,尾部加以下程式碼:
?1 2 |
window.$
= _temp$; //將$的引用許可權返還給jQuery1.3.
window.jQuery
= _tempjQuery; //將jQuery的引用許可權返還給jQuery1.3.
|
第三步:以後要用基於jQuery1.4.2的選取函式就只能用$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)的執行步驟,只不過第一步改為:
1 |
var
$j2 = jQuery.noConflict( true );
|
第三步用$j2(element)罷了。道理都是相同的。