jQuery.noConflict 方法包含一個可選的布爾參數[1],用以決定移交 $ 引用的同時是否移交 jQuery 對象本身:
代碼如下:
jQuery.noConflict([removeAll])
缺省情況下,執行 noConflict 會將變量 $ 的控制權移交給第一個產生 $ 的庫;當 removeAll 設置為 true 時,執行 noConflict 則會將 $ 和 jQuery 對象本身的控制權全部移交給第一個產生他們的庫。
例如在 KISSY 和 jQuery 混用,并且慣用 $ = KISSY 來簡化 API 操作的時候,就能夠通過這個方法解決命名沖突的問題。
那么這個機制是如何實現的呢?閱讀 jQuery 源碼開頭[2],首先做的一件事情是這樣的:
代碼如下:
// Map over jQuery in case of overwrite
_jQuery = window.jQuery,
// Map over the $ in case of overwrite
_$ = window.$,
容易理解的是,jQuery 通過兩個私有變量映射了 window 環境下的 jQuery 和 $ 兩個對象,以防止變量被強行覆蓋。一旦 noConflict 方法被調用,則通過 _jQuery, _$, jQuery, $ 四者之間的差異,來決定控制權的移交方式,具體的代碼如下:
noConflict: function( deep ) {
if ( window.$ === jQuery ) {
window.$ = _$;
}
if ( deep && window.jQuery === jQuery ) {
window.jQuery = _jQuery;
}
return jQuery;
}
再來看上面所說的參數設定問題,如果 deep 沒有設置,_$ 覆蓋 window.$,此時 jQuery 別名 $ 失效,但 jQuery 本身完好無損。如果有其他類庫或代碼重新定義了 $ 變量,它的控制權就完全交接出去了。反之如果 deep 設置為 true 的話,_jQuery 覆蓋 window.jQuery,此時 $ 和 jQuery 都將失效。
這種操作的好處是,不管是框架混用還是 jQuery 多版本共存這種高度沖突的執行環境,由于 noConflict 方法提供的移交機制,以及本身返回未被覆蓋的 jQuery 對象,完全能夠通過變量映射的方式解決沖突。
但無法避免的事實是可能導致的插件失效等問題,當然通過簡單修改上下文參數即可恢復 $ 別名:
代碼如下:
var query = jQuery.noConflict(true);
(function ($) {
// 插件或其他形式的代碼,也可以將參數設為 jQuery
})(query);
下面的示例一樣是解決這個問題的
jQuery自誕生以來,版本越來越多,而且jQuery官網的新版本還在不斷的更新和發布中,但是我們在以前的項目中就已經使用了舊版本的jQuery,比如已經出現的:1.3.X、1.4.X、1.5.X、1.6.2等等。
由于項目的需要,必然也需要不斷的使用較新版的jQuery,但對于原來就已經存在并已經采用了的舊jQuery版本,我們如何讓多個不同的jQuery版本在同一個頁面并存而不沖突呢?
其實,利用jQuery.noConflict()特性,我們不僅可以讓jQuery與其他的JS庫并存,比如Prototype。也可以與jQuery本身的其他不同版本并存而不沖突。
代碼如下:
我是'+$.fn.jquery+'版本添加進來的。
').appendTo('body');});我是'+$.fn.jquery+'版本添加進來的。
').appendTo('body');});我是'+$.fn.jquery+'版本添加進來的。
').appendTo('body');});聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com