• 可想实现一个自己的简单jQuery库?(九)


    Lesson-8


    事件机制

    在讲事件机制之前呢,我们有一个很重要的东西要先讲,那就是如何实现事件委托(代理).

    只有必须先明白了如何实现一个事件委托,我们才能更好的去实现on和off.在我看来,on和off里最难实现的就是他的事件委托.

    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;
                }
            }
        }
    }

    以上是我对整个委托的实现,当然在这只做了非常简单的实现,没有对很多别的情况进行判断,也没有多个参数是否捕捉.

    我们先拆解下分析.

    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就是我们具体的委托元素

    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的条件判断两个,第一个是是否阻止冒泡,第二个判断是冒泡是否到顶.

    接着我们进行filiter进行过滤,如果返回true,则是我们的委托元素,直接call即可.

    如果不做过多的兼容处理,实现一个委托还是比较容易的.

    PS:如果您还是不太明白,可以来这看更具体的解释.http://www.meckodo.com/?p=309

    您的star是检验代码的唯一标准!:)

    github地址: https://github.com/MeCKodo/forchange/tree/master/lesson-8
    可想实现一个自己的简单jQuery库?(八):http://segmentfault.com/a/1190000004025152

  • 相关阅读:
    AS3.0纯代码编写的两款loading效果
    AS3.0 Vector的运用
    java 垃圾回收总结(1)
    as3垃圾回收机制
    AS3.0 效率优化
    数组去重的方法
    javascript 的垃圾回收机制讲一下
    浅拷贝和深拷贝
    判断 js 类型的方式
    前端安全问题?
  • 原文地址:https://www.cnblogs.com/10manongit/p/12664968.html
Copyright © 2020-2023  润新知