可想实现一个本身的简单jQuery库?(九)

Lesson-8


事件机制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

相关文章
相关标签/搜索