解決jquery版本衝突問題

2021-09-12 05:24:18 字數 1417 閱讀 2619

解決jquery1.3.2和1.4.2的衝突。(測試通過)

第一步:在1.4.2的源**的最後加上一句 var $j4 = jquery.noconflict(true);//之所以在原始碼這裡加,而不是像大多數文章提的在要用到的時候加,這是因為很多基於1.4.2的外掛程式都要加,在這裡加可以避免過多外掛程式加這句**導致重複。這一句是將1.4.2的jquery和$的引用許可權全部放棄。也就是基於1.4.2的外掛程式不能再用jquery和$了。同時給予$j4的新的命名空間,注意它是window的屬性。看1.4.2的源**會發現它其實也就執行了這兩句: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;

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

a:我們不希望改動大量的jquery外掛程式源**,最好是不動,即使改的話,盡量改的少。而在頭部尾部加改動**,中間的原始**不動也是不錯的一種方式。

b:因為1.4.2的已經放棄了jquery和$的控制權,但是已有的外掛程式**又用了他們來做引用,因為外掛程式不可能預知衝突,即使有衝突他人開發的外掛程式也一定要用$或者jquery引用,除非它不是jquery下的外掛程式。

c:為了防止外掛程式裡面直接用window.$和window.jquery進行引用從而導致引用到1.3.2的jquery和$,雖然這種情況比較少,但是以防萬一。

【中間的原始**不動】

尾部加以下**

window.$ = _temp$;//將$的引用許可權返還給jquery1.3.

window.jquery = _tempjquery;//將jquery的引用許可權返還給jquery1.3.

第三步:以後要用基於jquery1.4.2的選取函式就只能用$j4(element)了。

總結:到目前為止可行方案:jquery1.4.2完全放棄$和jquery的控制許可權。1.3.2放棄$的控制許可權但不放棄j

query的許可權,其實jquery也可放棄,只不過要給個別名$j3。prototype最好放在jquery1.3.2後面,它獲得$的控制許可權。只是以後

要用jquery1.4.2就必須用$j4來引用了。但這樣即使有再多的jquery框架版本衝突問題,也全部解決掉了。假如來了個1.2的jquery怎麼辦,參照(2)的執行步驟,只不過第一步改為var $j2 = jquery.noconflict(true);第三步用$j2(element)罷了。道理都是相同的。

解決Jquery衝突的問題

jquery自誕生以來,版本越來越多,而且jquery官網的新版本還在不斷的更新和發布中,現已經達到了1.6.4版本,但是我們在以前的專案中就已經使用了舊版本的jquery,比如已經出現的 1.3.x 1.4.x 1.5.x 1.6.2等等。由於專案的需要,必然也需要不斷的使用較新版的jquery,...

git 解決版本衝突問題

當我們提交 時發現我們當前的版本master分支的 有衝突 首先 git rebase origin master 修改我們當前的分支並且併入master分支 然後 git status 檢視修改之後的狀態就可以檢視我們衝突的檔案 其次就是解決這些衝突檔案 然後再次加入快取區git add a 繼續...

解決多個jquery並存衝突問題

jquery自誕生以來,版本越來越多,而且jquery官網的新版本還在不斷的更新和發布中,現已經達到了1.6.4版本,但是我們在以前的專案中就已經使用了舊版本的jquery,比如已經出現的 1.3.x 1.4.x 1.5.x 1.6.2等等。由於專案的需要,必然也需要不斷的使用較新版的jquery,...