最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
jquery卸载全部事件的思路及实例
时间:2022-06-25 17:38:56 编辑:袖梨 来源:一聚教程网
原生js不支持匿名卸载事件的,jquery为了开发者好用支持了匿名的
匿名事件的思路
首先她会判断目标是否是元素或者对象,如果是元素,则在元素上打一个标识(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 = {};
jquery删除已存在的事件实例
Insert title here
相关文章
- myfreemp3音乐网站最新链接-myfreemp3在线音乐官网入口直达 02-11
- 女神漫画在线阅读最新版本下载免费漫画入口网址 - 女神漫画全集高清安装包免费漫画入口网页 02-11
- 豆包AI在线智能入口-豆包AI网页版直达 02-11
- 六便士与月亮是什么梗 02-11
- 韩漫高清免费阅读入口:海量精品漫画随心看 02-11
- 深夜年轻人必刷B站短视频-年轻人熬夜必备B站神器 02-11