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
看个例子:
当点击前三个的时候会依次弹出classname,其他的都不会触发事件
div#out > div#inner :ul :
- class="lia" attr-action="setWhat"
- class="lia" attr-action="setWhat"
- class="lia" attr-action="setWhat"
- class="lib"
- class="lib"
- class="lib"
效果如下:
再看看事件的绑定情况,跟我们绑定事件的情况一致:
以上所述就是本文的全部内容了,希望大家能够喜欢。