快速解決jQuery與其他庫沖突的方法介紹
通常,當在同一個頁面上使用jQuery和其他庫時,全局名稱$的定義是最大的爭論和沖突的焦點。眾所周知,jQuery使用$作為jQuery名稱的別名,并將其用于jQuery公開的每一個功能,但是其他庫,最著名的就是Prototype,也使用$名稱。
1. jQuery提供了$.noConflict()實用函數(shù)用來放棄對$標識符的占用,以便其他庫使用它。
該函數(shù)的語法如下:
$.noConflict(jqueryToo)
將標識符$的控制權(quán)歸還給其他庫,允許在頁面上混合使用jQuery與其他庫。一旦執(zhí)行了該函數(shù),必須使用jQuery標識符而不是$標識符來調(diào)用jQuery的功能,
你也可以放棄jQuery標識符(可選)
應該在包含了jQuery之后,但尚未包含沖突庫之前調(diào)用這個方法。
盡管使用的是jQuery標識符,但因為$是jQuery的別名,所以在應用$.noConflict()之后所有jQuery的功能依然可用。我們可以定義更短的,但沒有沖突的jQuery別名,例如
var $j = jQuery ;
2. 另一個常見的習慣用法是創(chuàng)建一個作用域環(huán)境,在該環(huán)境中$標識符指向jQuery對象,在擴展jQuery的時候這是個常用技巧,特別是對于插件作者來說,他們不可能對于頁面開發(fā)者是否已經(jīng)調(diào)用$.noConflict()作出任何假設(shè),當然也不能自行調(diào)用此函數(shù)以免破壞頁面開發(fā)者的意愿,
這個習慣用法如下:
(function($) { }) (jQuery);
(function($) { })
這部分聲明了一個函數(shù)并用圓括號括起來,由此生成一個表達式,這個表達式的結(jié)果是對一個匿名函數(shù)的引用,這個函數(shù)期望傳入單個參數(shù)并將其命名為$,在函數(shù)主體中,可以通過$標識符來引用任何傳遞給這個函數(shù)的東西。因為參數(shù)聲明優(yōu)先于全局作用域中任何類似的命名標識符,所以任何在函數(shù)外定義的$值在函數(shù)內(nèi)都會被傳入的參數(shù)所代替。
(jQuery)
在匿名函數(shù)上執(zhí)行函數(shù)調(diào)用,將jQuery對象作為參數(shù)傳遞
在函數(shù)外部不管$標識符是否已經(jīng)在Prototype或其他庫中定義,在函數(shù)體內(nèi)它總是指向jQuery對象。
當使用這個技巧時,外部聲明的$在函數(shù)體內(nèi)是不可用的。
3. 第二種的用法的一個變體也經(jīng)常用于聲明就緒處理函數(shù),從而形成了第三種語法,
jQuery( function($){
})
當編寫可重用的組件并且這些組件可能會用于已經(jīng)使用了$.noConflict()的頁面時,最好對$的定義采取這種預防措施。
相關(guān)文章
淺談jQuery中 wrap() wrapAll() 與 wrapInner()的差異
本文結(jié)合W3School的文檔,分析了jQuery中 wrap() wrapAll() 與 wrapInner()的差異,并給出了圖文對比教程,非常的簡單實用,有需要的朋友可以參考下2014-11-11JQuery中判斷一個元素下面是否有內(nèi)容或者有某個標簽的判斷代碼
網(wǎng)站開發(fā)時,我們時常需要把沒有內(nèi)容的標簽隱藏或者去掉。在用JQ有兩種好的解決辦法2012-02-02jQuery Validate 驗證,校驗規(guī)則寫在控件中的具體實例
本篇文章主要是對jQuery Validate 驗證,校驗規(guī)則寫在控件中的具體實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02jQuery實現(xiàn)漂亮實用的商品圖片tips提示框效果(無圖片箭頭+陰影)
這篇文章主要介紹了jQuery實現(xiàn)漂亮實用的商品圖片tips提示框效果,具有鼠標滑過顯示動態(tài)提示框的效果,涉及針對鼠標事件的響應及頁面元素動態(tài)操作技巧,需要的朋友可以參考下2016-04-04jQuery UI Autocomplete 1.8.16 中文輸入修正代碼
jQuery UI Autocomplete 1.8.16 中文輸入修正代碼,使用jQuery UI Autocomplete的朋友可以參考下2012-04-04