jquery插件沖突(jquery.noconflict)解決方法分享
許多的 JS 框架類庫都選擇使用$符號(hào)作為函數(shù)或變量名,jQuery是其中最為典型的一個(gè)。在 jQuery 中,$ 符號(hào)只是 window.jQuery 對(duì)象的一個(gè)引用,因此即使 $ 被刪除,window.jQuery 依然是保證整個(gè)類庫完整性的堅(jiān)強(qiáng)后盾。jQuery 的 API 設(shè)計(jì)充分考慮了多框架之間的引用沖突,我們可以使用 jQuery.noConflict 方法來輕松實(shí)現(xiàn)控制權(quán)的移交。
jQuery.noConflict 方法包含一個(gè)可選的布爾參數(shù)[1],用以決定移交 $ 引用的同時(shí)是否移交 jQuery 對(duì)象本身:
jQuery.noConflict([removeAll])
缺省情況下,執(zhí)行 noConflict 會(huì)將變量 $ 的控制權(quán)移交給第一個(gè)產(chǎn)生 $ 的庫;當(dāng) removeAll 設(shè)置為 true 時(shí),執(zhí)行 noConflict 則會(huì)將 $ 和 jQuery 對(duì)象本身的控制權(quán)全部移交給第一個(gè)產(chǎn)生他們的庫。
例如在 KISSY 和 jQuery 混用,并且慣用 $ = KISSY 來簡化 API 操作的時(shí)候,就能夠通過這個(gè)方法解決命名沖突的問題。
那么這個(gè)機(jī)制是如何實(shí)現(xiàn)的呢?閱讀 jQuery 源碼開頭[2],首先做的一件事情是這樣的:
// Map over jQuery in case of overwrite
_jQuery = window.jQuery,
// Map over the $ in case of overwrite
_$ = window.$,
容易理解的是,jQuery 通過兩個(gè)私有變量映射了 window 環(huán)境下的 jQuery 和 $ 兩個(gè)對(duì)象,以防止變量被強(qiáng)行覆蓋。一旦 noConflict 方法被調(diào)用,則通過 _jQuery, _$, jQuery, $ 四者之間的差異,來決定控制權(quán)的移交方式,具體的代碼如下:
noConflict: function( deep ) {
if ( window.$ === jQuery ) {
window.$ = _$;
}
if ( deep && window.jQuery === jQuery ) {
window.jQuery = _jQuery;
}
return jQuery;
}
再來看上面所說的參數(shù)設(shè)定問題,如果 deep 沒有設(shè)置,_$ 覆蓋 window.$,此時(shí) jQuery 別名 $ 失效,但 jQuery 本身完好無損。如果有其他類庫或代碼重新定義了 $ 變量,它的控制權(quán)就完全交接出去了。反之如果 deep 設(shè)置為 true 的話,_jQuery 覆蓋 window.jQuery,此時(shí) $ 和 jQuery 都將失效。
這種操作的好處是,不管是框架混用還是 jQuery 多版本共存這種高度沖突的執(zhí)行環(huán)境,由于 noConflict 方法提供的移交機(jī)制,以及本身返回未被覆蓋的 jQuery 對(duì)象,完全能夠通過變量映射的方式解決沖突。
但無法避免的事實(shí)是可能導(dǎo)致的插件失效等問題,當(dāng)然通過簡單修改上下文參數(shù)即可恢復(fù) $ 別名:
var query = jQuery.noConflict(true);
(function ($) {
// 插件或其他形式的代碼,也可以將參數(shù)設(shè)為 jQuery
})(query);
下面的示例一樣是解決這個(gè)問題的
jQuery自誕生以來,版本越來越多,而且jQuery官網(wǎng)的新版本還在不斷的更新和發(fā)布中,但是我們?cè)谝郧暗捻?xiàng)目中就已經(jīng)使用了舊版本的jQuery,比如已經(jīng)出現(xiàn)的:1.3.X、1.4.X、1.5.X、1.6.2等等。
由于項(xiàng)目的需要,必然也需要不斷的使用較新版的jQuery,但對(duì)于原來就已經(jīng)存在并已經(jīng)采用了的舊jQuery版本,我們?nèi)绾巫尪鄠€(gè)不同的jQuery版本在同一個(gè)頁面并存而不沖突呢?
其實(shí),利用jQuery.noConflict()特性,我們不僅可以讓jQuery與其他的JS庫并存,比如Prototype。也可以與jQuery本身的其他不同版本并存而不沖突。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>在同一個(gè)頁面中加載多個(gè)不同的jQuery版本</title>
<!-- 從谷歌服務(wù)器加載jQuery最新版本 -->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.js"></script>
<script type="text/javascript">
var jQuery_New = $.noConflict(true);
</script>
<!-- 加載jQuery1.6.2版本 -->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script>
<script type="text/javascript">
var jQuery_1_6_2 = $.noConflict(true);
</script>
<!-- 加載jQuery1.5.2版本 -->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script type="text/javascript">
var jQuery_1_5_2 = $.noConflict(true);
</script>
<!-- 加載jQuery1.4.2版本 -->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript">
var jQuery_1_4_2 = $.noConflict(true);
</script>
<!-- 加載jQuery1.3.2版本 -->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
<script type="text/javascript">
var jQuery_1_3_2 = $.noConflict(true);
</script>
<script type="text/javascript">
alert(jQuery_New.fn.jquery);
alert(jQuery_1_6_2.fn.jquery);
alert(jQuery_1_5_2.fn.jquery);
alert(jQuery_1_4_2.fn.jquery);
alert(jQuery_1_3_2.fn.jquery);
jQuery_New(function($){$('<p>我是最新的'+$.fn.jquery+'版本添加進(jìn)來的。</p>').appendTo('body');});
jQuery_1_6_2(function($){$('<p>我是'+$.fn.jquery+'版本添加進(jìn)來的。</p>').appendTo('body');});
jQuery_1_5_2(function($){$('<p>我是'+$.fn.jquery+'版本添加進(jìn)來的。</p>').appendTo('body');});
jQuery_1_4_2(function($){$('<p>我是'+$.fn.jquery+'版本添加進(jìn)來的。</p>').appendTo('body');});
jQuery_1_3_2(function($){$('<p>我是'+$.fn.jquery+'版本添加進(jìn)來的。</p>').appendTo('body');});
</script>
</head>
<body>
在同一個(gè)頁面中加載多個(gè)不同的jQuery版本
<br>
</body>
</html>
相關(guān)文章
jQuery截取指定長度字符串的實(shí)現(xiàn)原理及代碼
截取指定長度字符串操作在新聞列表這種類型的操作中大量應(yīng)用,下面有個(gè)示例,大家可以參考下2014-07-07
jQuery Pagination分頁插件_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
此jQuery插件為Ajax分頁插件,一次性加載,故分頁切換時(shí)無刷新與延遲,如果數(shù)據(jù)量較大不建議用此方法,因?yàn)榧虞d會(huì)比較慢。下面通過本文給大家分享jQuery Pagination分頁插件的使用方法及參數(shù)介紹,感興趣的朋友一起看看吧2017-07-07
jQuery實(shí)現(xiàn)表頭固定效果的實(shí)例代碼
jQuery實(shí)現(xiàn)表頭固定效果的實(shí)例代碼,需要的朋友可以參考一下2013-05-05
jquery+springboot實(shí)現(xiàn)文件上傳功能
這篇文章主要為大家詳細(xì)介紹了jquery+springboot文件上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
jQuery實(shí)現(xiàn)textarea自動(dòng)增長寬高的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)textarea自動(dòng)增長寬高的方法,涉及jQuery針對(duì)鍵盤按鍵的響應(yīng)及頁面元素的動(dòng)態(tài)操作技巧,需要的朋友可以參考下2015-12-12

