06月11, 2015

使用jquery卸载全部事件

说到事件,jquery做了不少,当然也有data的很多功劳,因为原生js不支持匿名卸载事件的,而她为了开发者好用支持了匿名的

匿名事件的思路

首先她会判断目标是否是元素或者对象,如果是元素,则在元素上打一个标识(expando)然后值是生成的一个guid,并在缓存对象下建立一个缓存,比如:

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

然后会在你触发元素事件时拿元素上的标识去往缓存里的events里找,并会有是否委托,选择器等判断,然后最终触发,卸载的时候其实是拿缓存里的handle卸载的,因为是一个...

如果目标不是元素,比如是一个window那么她会直接往目标上添加标识,比如:window[$.expando]

其实事件跟缓存有很深的关系,她们是蕾丝~

卸载全部事件

清空标识

这里的标识包括元素上的和对象上的

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

ps:因为window不是元素,但会有一些事件,比如scroll,resize

删除缓存

这里的缓存包括元素的缓存和对象缓存

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

本文链接:https://xuexb.com/post/267.html

-- EOF --

发表于 2015年06月11日 16:10:00 ,添加在分类 前端技术 下 ,并被添加「 jquery 事件 」标签 ,最后修改于 2017年03月29日 21:19:09

提醒: 本文最后更新于 3209 天前,文中所描述的信息可能已发生改变,请谨慎使用。

Comments

评论加载中...

注:如果长时间无法加载,请针对 disq.us | disquscdn.com | disqus.com 启用代理。

AltStyle によって変換されたページ (->オリジナル) /