关于事件处理的一些总结

发布于 2021-12-03 23:23:30 字数 1425 浏览 1217 评论 0

假定我们有如下的 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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

文章
评论
1057 人气
更多

推荐作者

夢野间

文章 0 评论 0

doggiejohn

文章 0 评论 0

就此别过

文章 0 评论 0

初见终念

文章 0 评论 0

qq_rvKjBH

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文