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 ...
随机推荐
- 【mark】linux 终端命令行下的快捷键(自己已验证所有)
说明: \c + a:表示ctrl+a \a + a:表示alt+a 命令列表: 1 移动: \c + a:将光标移到行首 \c + e:将光标移到行尾 \c + f:将光标向后(右)移动一个字符 \ ...
- TI公司Tina-ti和FilterProDesktop下载地址
http://www.ti.com/tool/tina-ti http://focus.ti.com/en/download/aap/DesignEnv/FilterPro-DT/FilterProD ...
- Beaglebone Black - 控制 BBB 板上的 LED 灯
BBB 的板上有五个 LED 灯,一个电源,四个其他指示灯,usr0 至 usr3 .这次学习是控制 usr0 至 3 让它们亮着,熄灭,闪.算是个 Hello World 实验.非常简单. 需要的材 ...
- MyBatis 内连接association 左外连接collection
前提条件: 学生表 (多 子表) 年级表(一 主表) 1,第一种情况:先查子表所有 student.sql.xml文件如何配 由于有多表连接,无法把查询结果直接封装成一个实体对象--------& ...
- strange error encountered today in ROS
I reinstalled my ubuntu system and also ROS. I tested slam_karto package when some strange error cam ...
- Protractor AngularJS测试框架教程
Protractor是一个建立在WebDriverJS基础上的端到端(E2E)的AngularJS JavaScript Web应用程序测试框架.Protractor全自动化真实的模拟用户在真正的浏览 ...
- C++中的一些定义
PS: 这篇博客用来记录一些一般的C++书中草草掠过的一些概念. 或者一些不太容易理解的概念的详细解释. 欢迎新手进入,欢迎高手指正! Orz . 引用: 为对象起了另外一个名字, 引用类型引用(re ...
- myeclipse10.05安装aptana
安装步骤: 1.下载aptana3.2 Eclipse Plugin插件. 下载地址:http://update1.aptana.org/studio/3.2/024747/index.html 2. ...
- eclipse查看jdk源码,及反编译查看
jdk中的包: dt.jar是关于运行环境的类库,主要是swing的包 tools.jar是关于一些工具的类库 rt.jar包含了jdk的基础类库,也就是你在java doc里面看到的所有的类的cla ...
- C#操作Excel数据增删改查(转)
C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文件,并添加两张工作表. 工作表1: UserInfo表,字段:UserId.UserName.Age.Address.CreateT ...