溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用jQuery卸載全部事件的思路詳解

發(fā)布時間:2020-10-17 13:03:18 來源:腳本之家 閱讀:144 作者:mrr 欄目:web開發(fā)

說到事件, jquery 做了不少,當(dāng)然也有 data 的很多功勞,因為原生 js 不支持匿名卸載事件的,而她為了開發(fā)者好用支持了匿名的

匿名事件的思路

首先她會判斷目標(biāo)是否是元素或者對象,如果是元素,則在元素上打一個標(biāo)識( expando )然后值是生成的一個 guid ,并在緩存對象下建立一個緩存,比如:

$.cache={
  '2': {
    data: {},
    events: {},
    handle: function(){}
  },
}

然后會在你觸發(fā)元素事件時拿元素上的標(biāo)識去往緩存里的 events 里找,并會有是否委托,選擇器等判斷,然后最終觸發(fā),卸載的時候其實是拿緩存里的 handle 卸載的,因為是一個...

如果目標(biāo)不是元素,比如是一個 window 那么她會直接往目標(biāo)上添加標(biāo)識,比如: window[$.expando]

其實事件跟緩存有很深的關(guān)系,她們是蕾絲~

卸載全部事件

清空標(biāo)識

這里的標(biāo)識包括元素上的和對象上的

$('*').add(window).each(function(){
  try{
    delete this[$.expando];
  }catch(e){}
});

ps:因為 window 不是元素,但會有一些事件,比如 scroll , resize 等

刪除緩存

這里的緩存包括元素的緩存和對象緩存

window[$.expando] = {}
$.cache = {};

以上所述上小編給大家介紹的使用jQuery卸載全部事件的思路詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI