• 技术文章 >web前端 >js教程

    js中的事件委托

    小云云小云云2018-03-14 16:59:07原创1037

    本文主要和大家分享js中的事件委托实例详解,我们主要和大家分享两个内容1.事件委托的原理以及优缺点 2. 手写原生js实现事件代理,并要求兼容浏览器。

    Q:事件的委托(代理 Delegated Events)的原理以及优缺点

    A:委托(代理)事件是那些被绑定到父级元素的事件,但是只有当满足一定匹配条件时才会被挪。这是靠事件的冒泡机制来实现的,

    优点是:

    (1)可以大量节省内存占用,减少事件注册,比如在table上代理所有td的click事件就非常棒

    (2)可以实现当新增子对象时无需再次对其绑定事件,对于动态内容部分尤为合适

    缺点是:

    事件代理的应用常用应该仅限于上述需求下,如果把所有事件都用代理就可能会出现事件误判,即本不应用触发事件的被绑上了事件。

    例子:

    var toolbar = document.querySelector(".toolbar");
    toolbar.addEventListener("click", function(e) {
      var button = e.target;
      if(!button.classList.contains("active"))
        button.classList.add("active");
      else
        button.classList.remove("active");
    });



    单击button元素会冒泡到UL.toolbar元素,使用了e.target来定位到当前点击的button。

    Q:手写原生js实现事件代理,并要求兼容浏览器

    A:其实就是考核对事件对象e的了解程度,以及在IE下对应的属性名。

    查看Demo

    function delegateEvent(interfaceEle, selector, type, fn) {// ============ 简单的事件委托
        if(interfaceEle.addEventListener){
        interfaceEle.addEventListener(type, eventfn);
        }else{
        interfaceEle.attachEvent("on"+type, eventfn);
        }
        function eventfn(e){
        var e = e || window.event;    
        var target = e.target || e.srcElement;
     
      
     //如果目标元素与选择器匹配则执行函数
        if (matchSelector(target, selector)) {
                if(fn) {
     //将fn内部的this指向target(在此之前this都是指向的绑定事件的元素即interfaceEle)
                    fn.call(target, e); 
                }
            }
        }
    }
    /**
     * only support #id, tagName, .className
     * and it's simple single, no combination
     */
    //比较函数:判断事件的作用目标是否与选择器匹配;匹配则返回true
    function matchSelector(ele, selector) {
        //
     如果选择器为ID
        if (selector.charAt(0) === "#") {
                
            return ele.id === selector.slice(1);
       
        }
     
         //charAt(0),返回索引为0的字符
     
       //slice(a,b),从已有的数组或字符串返回从索引从a处开始,截取到索引b之前的子数组或子字符串;
        //如果选择器为Class
        if (selector.charAt(0) === ".") {
            return (" " + ele.className + " ").indexOf(" " + selector.slice(1) + " ") != -1;
        }
        //
     如果选择器为tagName
        return ele.tagName.toLowerCase() === selector.toLowerCase();
    }
    //toLowerCase()将字符串转换成小写
    //调用
    var op = document.getElementById("op");
    delegateEvent(op,"a","click",function(){
        alert("1");
    })

    相关推荐:

    JS事件委托实例详解

    以上就是js中的事件委托的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript 委托 事件
    上一篇:js面向对象实例讲解 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 深入浅析Node中的进程和线程• 一文探究Angular中的服务端渲染(SSR)• react怎么实现列表排序• 一文聊聊Node包管理发展的五个阶段• 带你了解Angular组件间进行通信的几种方法
    1/1

    PHP中文网