关于事件处理的一些总结
假定我们有如下的 dom 结构
<div class="container">
<div class="article-list>
<div class="article">
<h3 class="title">召开了大会</h3>
<p class="desc">会议主要介绍了若干事项</p>
</div>
<div class="article">
<h3 class="title">召开了大会</h3>
<p class="desc">会议主要介绍了若干事项</p>
</div>
</div>
</div>
article 列表是动态渲染出来的,我们希望在点击 article 的时候,进行跳转处理,自己用代码实现 delegate:
$ = function(dom) {
this.dom = dom;
}
$.prototype.delegate(event, selector, handler) {
this.dom.addEventListener(event, function(evt){
var nodelist = document.querySelectorAll(selector);
var node = Array.prototype.find.call(nodelist, function(e){
return e == evt.target;
});
if(node) {
handler(evt);
}
})
return this;
}
实际调用的代码会发现点击在 title 上的时候不会触发函数
$(document.querySelector('.container')).delegate('click', '.article', function(){
console.log('trigger...');
});
分析得出结论是,从 title
上触发的点击事件,一直冒泡到 .container 才被捕获,捕获以后判定的是 event.target
equal .article
,实际上判定应该做的是event.target
equal .article
or is child of .article
。这样,当我们点击的是 .title 得到的 event.target 是 .title
,点击的 .article 的时候得到的 dom 是 .article
,并且都能执行处理。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: 事件流的实用总结
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论