jQuery 2.0.3 源码分析 bind/live/delegate/on
传统的时间处理:
给某一个元素绑定一个点击事件,传入一个回调句柄处理
element.addEventListener('click',doSomething,false);
这样的绑定如果页面上面有几百个需要绑定,那么就要绑定几百多次。
问题:
大量的事件绑定,性能消耗,而且还需要解绑(IE会泄露)
绑定的元素必须要存在。
后期生成HTML会没有事件绑定,需要重新绑定。
语法过于繁杂
事件委托
DOM有个事件流的特性,在页面上触发节点的时候事件都会上下或者向上传播,事件捕捉和事件冒泡。
事件传送可以分为3个阶段:
在事件Capturing捕捉阶段,时间将沿着DOM数向下转送,目标节点的每一个祖先节点,直至目标节点,
在目标target阶段,浏览器在查找到已经指定给目标事件的事件监听器之后,就会运行该事件监听器,目标节点就是触发事件的DOM节点。
在冒泡bubbling阶段,事件将沿着DOM树向上转送,再次逐个访问目标元素的祖先节点到document节点,该过程中的每一步,浏览器都将检测那些不是捕捉事件监听器的事件监听器,并执行他们,
利用事件传播这个机制,就可以实现事件委托。
事件委托就是时间目标自身不处理事件,而是吧处理任务委托给其他父元素或者祖先元素,甚至根元素。
jquery的事件优化.bind(),.live(),.on(),.delegate()
on()方法事件处理程序到当前选定的jquery对象中的元素,提供绑定事件处理的所有功能。
性能对比
生成999个DOM节点,不做任何处理,内存消耗2.2M
给每个元素绑定click事件。增加到5.6M,用on2.2M
只要on的delegate对象是HTML页面缘由的元素,由于是事件的触发是通过Javascript的事件冒泡机制来检测,所以对于所有子元素所有的事件监测均能有效,且由于不用对多个元素进行事件绑定,能够有效的节省内存的损耗。
bing()方法用于直接附加一个事件处理程序到元素上。
处理程序附加到jquery对象中当前选中的元素,所以,在bing()绑定事件的时候,这些元素必须已经存在。
live()将委托的事件处理程序附加到一个页面的decument元素,从而简化了在页面上动态添加的内容上事件处理的使用,
例子:$('a').live('click'.function(){alert('2121')});
jquery把alert函数绑定到$(document)元素上,并使用click和a做为参数。
任何时候只要在事件冒泡到document节点上,他就查看该事件是否是一个click事件,以及该事件的目标元素与a这一css选择权是否匹配,如果都是的话,则执行函数。
使用live()会出现的问题:
在调用live方法之前,jquery会先获取与指定的选择权匹配的元素, 这一点对于大型文档来说是很花费时间的。
不支持链式写法,$('a').find('').live(),不支持。
由于所有的live事件被添加到document元素上,所以在事件被处理之前,可能回通过最长最慢的那条路径之后才能被触发。
在事件处理中调用event.stopPropagation()来阻止事件内添加到document之后的节点中,是效率很低的,因为事件已经被传播到document上。
delegate
$(#element).delegate('a','click',function(){alert('1212')});
jquery查找#element,并使用click事件和a这一css选择权作为参数把alert函数绑定到#element上。
任何时候只要有事件冒泡到#element上,他就查看该事件是否是click事件,以及该事件的目标元素是否与css选择器匹配,如果两种检查的结果都为真的话,他就执行函数.
这一过程与live类似, 但是它把处理程序绑定带具体的元素而非document这一根上,
('a').live()==document.delegate('a')?
delegata方法是一个相对完美的解决方案,但在DOM结构简单的情况在,也可以使用live().
on
其实bind,live,delegate都是通过on()来实现的,unbind,die,undelegate,也是一样的都是通过off来实现的,
在下列情况下,应该使用live或delegate,而不能使用bind
为DOM中的很多元素绑定相同事件。
为DOM中尚不存在的元素绑定事件。
用bind的代价是非常大的,他会把相同的一个事件处理程序hook到所有匹配的DOM元素上,不要再用live了,他已经不再推荐了,而且还有很多问题。
delegate会提供很好的方法来提高效率,同时我们可以添加一事件处理方法到动态添加的元素上,
jQuery 2.0.3 源码分析 bind/live/delegate/on的更多相关文章
- jQuery 2.0.3 源码分析Sizzle引擎解析原理
jQuery 2.0.3 源码分析Sizzle引擎 - 解析原理 声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 先来回答博友的提问: 如何解析 div > p + ...
- jQuery 2.0.3 源码分析 事件绑定 - bind/live/delegate/on
事件(Event)是JavaScript应用跳动的心脏,通过使用JavaScript ,你可以监听特定事件的发生,并规定让某些事件发生以对这些事件做出响应 事件的基础就不重复讲解了,本来是定位源码分析 ...
- jQuery 2.0.3 源码分析 事件体系结构
那么jQuery事件处理机制能帮我们处理那些问题? 毋容置疑首先要解决浏览器事件兼容问题 可以在一个事件类型上添加多个事件处理函数,可以一次添加多个事件类型的事件处理函数 提供了常用事件的便捷方法 支 ...
- jQuery 2.0.3 源码分析 Deferred(最细的实现剖析,带图)
Deferred的概念请看第一篇 http://www.cnblogs.com/aaronjs/p/3348569.html ******************构建Deferred对象时候的流程图* ...
- jQuery 2.0.3 源码分析core - 选择器
声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 打开jQuery源码,一眼看去到处都充斥着正则表达式,jQuery框架的基础就是查询了,查询文档元素对象 ...
- jQuery 2.0.3 源码分析 Deferred概念
JavaScript编程几乎总是伴随着异步操作,传统的异步操作会在操作完成之后,使用回调函数传回结果,而回调函数中则包含了后续的工作.这也是造成异步编程困难的主要原因:我们一直习惯于“线性”地编写代码 ...
- jQuery 2.0.3 源码分析 Deferrred概念
转载http://www.cnblogs.com/aaronjs/p/3348569.html JavaScript编程几乎总是伴随着异步操作,传统的异步操作会在操作完成之后,使用回调函数传回结果,而 ...
- jQuery 2.0.3 源码分析core - 整体架构
拜读一个开源框架,最想学到的就是设计的思想和实现的技巧. 废话不多说,jquery这么多年了分析都写烂了,老早以前就拜读过, 不过这几年都是做移动端,一直御用zepto, 最近抽出点时间把jquery ...
- jQuery 2.0.3 源码分析Sizzle引擎 - 解析原理
声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 先来回答博友的提问: 如何解析 div > p + div.aaron input[type="checkb ...
随机推荐
- Java_JDK_HashMap
(二)HashMap 需要注意的无非几点: 是什么结构,如何存储的? 如何加入元素?既然是hashMap,那么是如何计算hashcode的呢?遇到冲突又是如何解决的呢? 如何删除元素? 当容量不够时是 ...
- Set Font Properties On Mouse Hover Of Push Button And Text Items At Run time In Oracle Forms
Change the font size and weight of text items and push buttons on mouse hover in Oracle Forms. An ...
- spring引入实体类映射文件
由于spring对hibernate配置文件hibernate.cfg.xml的集成相当好 LocalSessionFactoryBean有好几个属性用来查找hibernate映射文件: mapp ...
- [POJ1830]开关问题(高斯消元,异或方程组)
题目链接:http://poj.org/problem?id=1830 题意:中文题面,求的是方案数. 首先可以知道, 如果方案数不止一个的话,说明矩阵行列式值为0,即存在自由变元,由于变量只有两种状 ...
- oracle小测试
1.请解释以下几个函数意思:NVL.TRUNC.DECODE.TO_DTAE.TO_CHAR.CONVERT.ROUND.TRIM.ISNULL.SUBSTR.GROUP BY.HAVING 答: N ...
- poj 2954 Triangle(Pick定理)
链接:http://poj.org/problem?id=2954 Triangle Time Limit: 1000MS Memory Limit: 65536K Total Submissio ...
- python_way day18 html-day4, Django路由,(正则匹配页码,包含自开发分页功能), 模板, Model(jDango-ORM) : SQLite,数据库时间字段插入的方法
python_way day18 html-day4 1.Django-路由系统 - 自开发分页功能 2.模板语言:之母板的使用 3.SQLite:model(jDango-ORM) 数据库时间字 ...
- 关于Ubuntu中passwd、shadow、group等文件
在Ubuntu系统中,/etc目录下,有三个文件:passwd shadow group,可能我们已经在用了,但是没有注意到其详细. 这三个配置文件用于系统帐号管理,都是文本文件,可用vi等文本编辑器 ...
- ubuntu 14.0.04 通过自启动脚本实现主机和虚拟机的文件夹共享
首先要先设置主机ip为固定ip: 1.vi /etc/rc.local,进入vi界面,在尾部增加一行代码: mount -t cifs -o username=share,password=12345 ...
- white-space: nowrap
CSS:需要加上宽度(width:100px).超出隐藏(overflow:hidden;).强制在同一行显示(white-space: nowrap;).省略号(text-overflow:elli ...