极乐门资源网 Design By www.ioogu.com
js事件绑定
事件绑定,这里使用了冒泡的原理,从点击的元素开始,递归方式的向父元素传播事件,这样做的好处是对于大量要处理的元素,不必为每个元素都绑定事件,只需要在他们的父元素上绑定一次即可,提高性能。还有一个好处就是可以处理动态插入dom中的元素,直接绑定的方式是不行的。
之前一直使用的是jquery的on方法做这样的事情,前几天看到公司项目中有实现这种方式的源代码,拿来仔细研究研究,跟大家分享分享。
function $bindAction(dom, event, listeners) { #这里的dom为绑定事件的元素,比如document.body #event为绑定的事件,比如click #listeners是待执行的事件对象 $addEvent(dom, event, function(e) { #这里获取事件e #获取点击的元素src var e = e || window.event, src = e.target || e.srcElement, action, returnVal; #模拟冒泡的方式,先是src,然后是src.parentNode,再然后是src.parentNode.parent.Node #当前dom元素等于事件绑定的dom元素的时候,停止“冒泡” while (src && src !== dom) { #循环获取dom元素的attr-action属性, action = src.getAttribute('attr-action'); #如果当前dom元素存在attr-action属性,并且事件对象中有该属性值的函数,执行这个函数 #将事件e、当前dom元素、元素的属性attr-action值传给要执行的函数 if (listeners[action]) { returnVal = listeners[action]({ src : src, e : e, action : action }); #如果上面的函数执行之后返回false,停止继续“冒泡” if (returnVal === false) { break; } } #获取当前dom元素的父元素节点 src = src.parentNode; } }); }; function $addEvent(obj, type, handle) { if(!obj || !type || !handle) { return; } #绑定事件到多个对象,递归调用 if( obj instanceof Array) { for(var i = 0, l = obj.length; i < l; i++) { $addEvent(obj[i], type, handle); } return; } #绑定多个事件,递归调用 if( type instanceof Array) { for(var i = 0, l = type.length; i < l; i++) { $addEvent(obj, type[i], handle); } return; } #下面这一大段用来记录当前页面一共绑定了多少个事件,以及事件的相关信息 #以及某个对象上面绑定的事件id window.__allHandlers = window.__allHandlers || {}; window.__Hcounter = window.__Hcounter || 0; function setHandler(obj, type, handler, wrapper) { obj.__hids = obj.__hids || []; var hid = 'h' + ++window.__Hcounter; obj.__hids.push(hid); window.__allHandlers[hid] = { type : type, handler : handler, wrapper : wrapper } } #这个里面的apply是为了修改绑定事件所执行函数中的this #这个在低版本的IE中才真正起作用 function createDelegate(handle, context) { return function() { return handle.apply(context, arguments); }; } #绑定事件,记录事件绑定信息 if(window.addEventListener) { var wrapper = createDelegate(handle, obj); setHandler(obj, type, handle, wrapper) obj.addEventListener(type, wrapper, false); } else if(window.attachEvent) { var wrapper = createDelegate(handle, obj); setHandler(obj, type, handle, wrapper) obj.attachEvent("on" + type, wrapper); } else { obj["on" + type] = handle; } };
看个例子:
当点击前三个的时候会依次弹出classname,其他的都不会触发事件
<style type="text/css"> #out{width: 500px;background-color: #CDE} #inner{background-color: #ABCDEF;margin: 0;padding: 0;width: 400px;} ul{background-color: pink;margin: 0;padding: 0;width: 400px;} li{width:398px;height: 20px;border: 1px solid black;margin: 15px 0px;padding: 0px;list-style: none;} </style> div#out > div#inner : <div id="out"> <ul id="inner"> <li class="lia" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lia" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lib" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lib">class="lib"</li> <li class="lib">class="lib"</li> <li class="lib">class="lib"</li> </ul> </div> ul : <ul> <li class="lia" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lia" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lib" attr-action="setWhat">class="lia" attr-action="setWhat"</li> <li class="lib">class="lib"</li> <li class="lib">class="lib"</li> <li class="lib">class="lib"</li> </ul> <script> listeners = { setWhat : function(opts) { alert(opts.src.className); return false; }, }; window.onload = function(){$bindAction(document.getElementById('out'), ['click', 'mouseover'], listeners);} </script>
效果如下:
再看看事件的绑定情况,跟我们绑定事件的情况一致:
以上所述就是本文的全部内容了,希望大家能够喜欢。
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无javascript事件委托的方式绑定详解的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年01月18日
2025年01月18日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]