事件机制javascript
在讲事件机制以前呢,咱们有一个很重要的东西要先讲,那就是如何实现事件委托(代理).java
只有必须先明白了如何实现一个事件委托,咱们才能更好的去实现on和off.在我看来,on和off里最难实现的就是他的事件委托.node
function delegate(agent,type,selector,fn) { agent.addEventListener(type,function(e) { var target = e.target; var ctarget = e.currentTarget; var bubble = true; while(bubble && target != ctarget) { if(filiter(agent,selector,target)) { bubble = fn.call(target,e); } target = target.parentNode; return bubble; } },false); function filiter(agent,selector,target) { var nodes = agent.querySelectorAll(selector); for (var i = 0; i < nodes.length; i++) { if (nodes[i] == target) { return true; } } } }
以上是我对整个委托的实现,固然在这只作了很是简单的实现,没有对不少别的状况进行判断,也没有多个参数是否捕捉.git
咱们先拆解下分析.github
function filiter(agent,selector,target) { var nodes = agent.querySelectorAll(selector); for (var i = 0; i < nodes.length; i++) { if (nodes[i] == target) { return true; } } }
先看这个方法,这其实就是一个元素过滤,做用就是为了过滤出咱们委托的元素具体是谁.target就是咱们具体的委托元素segmentfault
agent.addEventListener(type,function(e) { var target = e.target; var ctarget = e.currentTarget; var bubble = true; //是否阻止冒泡 while(bubble && target != ctarget) { if(filiter(agent,selector,target)) { bubble = fn.call(target,e); } target = target.parentNode; return bubble; } },false);
而后是咱们的主要部分.其实这里就很简单,while的条件判断两个,第一个是是否阻止冒泡,第二个判断是冒泡是否到顶.less
接着咱们进行filiter进行过滤,若是返回true,则是咱们的委托元素,直接call便可.代理
若是不作过多的兼容处理,实现一个委托仍是比较容易的.code
PS:若是您仍是不太明白,能够来这看更具体的解释.http://www.meckodo.com/?p=309事件
您的star是检验代码的惟一标准!:)
github地址: https://github.com/MeCKodo/forchange/tree/master/lesson-8
可想实现一个本身的简单jQuery库?(八):http://segmentfault.com/a/1190000004025152