时间:2021-05-26
什么是事件委托/事件代理
利用事件的冒泡传播机制(触发当前元素的某一个行为,它父级所有元素的相关行为都会被触发),如果一个容器中有很多元素都要绑定点击事件,我们没有必要一个个的绑定了,只需要给最外层容器绑定一个点击事件即可,在这个方法执行的时候,通过事件源的区分来进行不同的操作。
具体小案例如下:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title> <style> *{ margin:0; padding:0; font-size:14px; } html,body{ width:100%; height:100%; overflow:hidden; } #box{ position:absolute; left:50%; top:50px; width:100px; height:30px; margin-left:-50px; line-height:30px; text-align:center; border:1px solid #2489cc; } #mark{ position:absolute; top:30px; left:-1px; width:300px; height:100px; line-height:100px; text-align:center; background:#ffe470; border:1px solid #2489cc; } </style></head><body> <div id='box'> <span>购物车</span> <div id="mark" style='display:none'> 查看购物车的详细信息 </div> </div> <script> var mark = document.getElementById('mark'); document.body.onclick = function(e){ e = e || window.event; e.target = e.target || e.srcElement; //如果点击的是box或者是#box下的span,我们判断mark是否显示,显示让其隐藏,反之让其显示 if(e.target.id==="box" || (e.target.tagName.toLowerCase()==="span" && e.target.parentNode.id==='box')){ if(mark.style.display === "none"){ mark.style.display === "block" }else{ mark.style.display === "none" } return; } //如果事件源是#mark,不进行任何的操作 if(e.target.id==="mark"){ return; } mark.style.display === "none" } </script></body></html>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS中的事件委托。分享给大家供大家参考,具体如下:事件委托(也叫事件代理),其实这个问题也简单,要想弄明白事件委托,我们先要把事件冒泡的机制搞清楚
JavaScript事件代理(委托)一般用于以下情况:1.事件注册在祖先级元素上,代理其子级元素。可以减少事件注册数量,节约内存开销,提高性能。2.对js动态添
本文实例讲述了JavaScript事件委托用法。分享给大家供大家参考。具体分析如下:一、点击页面任何部分触发事件创建一个script1.js文件。复制代码代码如
其所谓的动态添加事件实质就是指js中的事件委托。我们知道在js中,事件处理只能绑定在当前被选中的元素上,换句话也就是说,事件处理只能绑定在当前文档已经存在的元素
本文实例分析了C#中委托和事件的区别,分享给大家供大家参考之用。具体如下:大致来说,委托是一个类,该类内部维护着一个字段,指向一个方法。事件可以被看作一个委托类