js中的事件委托

本文主要和大家分享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 *///比较函数:判断事件的作用目标是否与选择器匹配;匹配则返回truefunction 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中的事件委托的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2782784.html

(0)

关于作者

上一篇 2025年3月8日 16:38:26
下一篇 2025年3月8日 16:38:32

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论