讀jQuery之十二 刪除事件核心方法
.remove 所作的事情與上一篇提到的.add 剛好相反。且與.add中的處理代碼一一對(duì)應(yīng),即 .add 中有多少種添加事件的方式.remove就有對(duì)應(yīng)的刪除方式。
.remove 定義了四個(gè)參數(shù) elem, types, handler, pos 。從字面上看四個(gè)參數(shù)的意義很明了
elem 為HTMLElement
types 為String類型,事件名稱如'click'或'mouseover mouseout'
handler 為Function類型,事件回調(diào)函數(shù)
pos 為Number類型,指定數(shù)組位置
但.remove內(nèi)部沒這么簡(jiǎn)單,如
1,handler 有時(shí)會(huì)傳布爾類型false,這時(shí)會(huì)把handler賦值為另一個(gè)函數(shù)(此處的處理同.add)。
if ( handler === false ) {
handler = returnFalse;
}
2, types 有時(shí)會(huì)為一個(gè)對(duì)象,這時(shí)真正的handler是types.handler,types是types.type。
// types is actually an event object here
if ( types && types.type ) {
handler = types.handler;
types = types.type;
}
我們知道變量命名要具有意義,名副其實(shí)而避免誤導(dǎo)。從這個(gè)意義上講,jQuery中存在大量這樣的寫法,一個(gè)變量往往具有多種含義,晦澀難讀。如這里的types,應(yīng)該是String類型,但實(shí)際內(nèi)部對(duì)typeos為Object類型也做了處理。這是JS沒有類型檢查的原因?qū)е?。反過來講這種語言會(huì)比較靈活,jQuery才如此 緊湊,內(nèi)聚。
閑言少敘,看看.remove方法都做了哪些事。
1、當(dāng)只傳elem時(shí),會(huì)將elem上添加的所有事件都刪除。如$('#id').unbind()
2、當(dāng)types為String,且以點(diǎn)號(hào)(.)開頭時(shí)將刪除該命名空間下的事件。如$('#id').unbind('.name')。會(huì)把添加click.name,mouseover.name等都刪除。
對(duì)應(yīng)的代碼如下
// Unbind all events for the element
if ( !types || typeof types === "string" && types.charAt(0) === "." ) {
types = types || "";
for ( type in events ) {
jQuery.event.remove( elem, type + types );
}
return;
}
我們發(fā)現(xiàn)for in中是個(gè)遞歸調(diào)用。
如果這么調(diào)用
jQuery.event.remove(el, 'click', fn)
那么是不會(huì)走上面的遞歸的,而是直接進(jìn)入了while循環(huán)
while ( (type = types[ i++ ]) ) {
...
}
這是標(biāo)準(zhǔn)的刪除事件的流程。大概步驟如下
1、判斷事件名稱是否具有命名空間(以點(diǎn)號(hào)區(qū)分),如果沒有命名空間則刪除該事件名稱下的所有事件。否則只刪除命名空間的某事件。
2、取得事件數(shù)組(eventType = events[ type ]),如果沒有傳handler則表示刪除該類型事件的所有hanlder,否則只刪除該事件類型的指定handler。
3、對(duì)特殊事件(如live)的處理
4、最后對(duì)elemData進(jìn)行處理,如果events為空對(duì)象則刪除elemData的events和handle屬性。如
// Remove the expando if it's no longer used
if ( jQuery.isEmptyObject( events ) ) {
var handle = elemData.handle;
if ( handle ) {
handle.elem = null;
}
delete elemData.events;
delete elemData.handle;
if ( jQuery.isEmptyObject( elemData ) ) {
jQuery.removeData( elem, undefined, true );
}
}
jQuery事件管理數(shù)據(jù)結(jié)構(gòu)圖:
相關(guān)文章
jQuery在IE下使用未閉合的xml代碼創(chuàng)建元素時(shí)的Bug介紹
這個(gè)偏門Bug是我在更新phZoom 1.29后發(fā)現(xiàn)的, 我先將之重現(xiàn)一下2012-01-01基于jQuery的可用于選項(xiàng)卡及幻燈的切換插件
最近公司項(xiàng)目頁面中用到選項(xiàng)卡與幻燈比較多,特地寫了個(gè)集選項(xiàng)卡、幻燈片與播放控制于一體的插件,同頁面可多次使用。2011-03-03jQuery使用jsonp實(shí)現(xiàn)百度搜索的示例代碼
這篇文章主要介紹了jQuery使用jsonp實(shí)現(xiàn)百度搜索,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07JQuery的Ajax跨域請(qǐng)求原理概述及實(shí)例
ajax跨域請(qǐng)求的問題,JQuery對(duì)于Ajax的跨域請(qǐng)求有兩類解決方案,不過都是只支持get方式,接下來為大家詳細(xì)介紹下客戶端JQuery.ajax的調(diào)用代碼2013-04-04