当前位置:首页 » 《随便一记》 » 正文

手写一个通用事件监听函数_I-AM-Yang的博客

18 人参与  2022年03月20日 13:59  分类 : 《随便一记》  评论

点击全文阅读


在准备js面试题时,遇到了许多知识盲区,或是已经遗忘的知识,所以来写一下博客,记录自己的成长,同时查漏补缺

这次来写一个通用的事件监听函数,基于我们的事件冒泡,如果你不知道事件冒泡

需求,点击每个a,返回对应的内容

 <div id="div">
    <a id="p1" href="#">激活</a>
    <a id="p2" href="#">取消</a>
    <a id="p3" href="#">取消</a>
    <a id="p4" href="#">取消</a>
    <a id="p5" href="#">激活</a>
    <a id="p6" href="#">取消</a>
    <a id="p7" href="#">取消</a>
    <a id="p8" href="#">取消</a>
    <button class="btn">加载更多...</button>
  </div>

先封装一个函数,看代码

function bindEvent(elem, type, fn) {
  elem.addEventListener(type,fn)
}
//调用时,如
bindEvent(div,'click',function(){})

是这样吗?当然不是,要是这么简单那面试时就没什么可问的了

我们写的要考虑上事件代理这个情况让这个函数可以使用事件代理,也可以不用事件代理

function bindEvent(elem, type, selector, fn) {
  //判断一下,如果我们只传入三个值,那就是普通函数
  //如果是传入四个参数,那就是使用事件代理
  //selector是我们要代理的对象,如果没有,那就不是使用事件代理
  if(fn == null) {
    fn = selector
    selector = null
  }
  elem.addEventListener(type, function(e) {
    const target = e.target
    if(selector) {
      //使用事件代理
      if(target.matches(selector)) {
        //这matches主要是用来判断当前DOM节点是否能完全匹配对应的CSS选择器规则;
         //如果匹配成功,返 回true,反之则返回false
        //可以理解为当我们传入的selector===target.nodeName,返回true,否则false
        fn.call(target, e)
        //使用call函数,方便我们使用this指向我们点击的元素
      }
    }else {
      //普通调用
      fn.call(target, e)
    }
  })
}

 使用代理时

bindEvent(div1,'click','a',function() {
  alert(this.innerHTML)
})
//点击每个a时,都可以alert出a的值

使用普通函数时

bindEvent(div1,'click',function(e) {
  const target = e.target
  if(target.nodeName === 'A') {
    alert(target.innerHTML)
  }
})
//点击每个a时,都可以弹出相对应的值


点击全文阅读


本文链接:http://zhangshiyu.com/post/36397.html

事件  代理  取消  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • (此去经年无故人)南初陆南城:结局+番外精品选集起点章节+阅读即将发布预订
  • 沈凝夏叶晚怡附加完整在线阅读(归雁不栖故人枝)最近更新列表
  • 剧情人物是时初,白浩雄的玄幻言情小说《召诸神,踏万界,天命帝女逆乾坤》,由网络作家&ldquo;海鸥&rdquo;所著,情节扣人心弦,本站TXT全本,欢迎阅读!本书共计381345字,185章节,:结局+番外免费品鉴:结局+番外评价五颗星
  • 凤青禾,江明远,***枢小说(别人修仙我捡漏,卷王们破防了)最近更新(凤青禾,江明远,***枢)整本无套路阅读
  • 薛梨小说无删减+后续(曾经亲情似草芥)畅享阅读
  • 沈南栀小说(穿越时空,我要修补时空裂缝)章节目录+起点章节(沈南栀)全篇清爽版在线
  • 未婚妻被巨蟒缠身,我该吃就吃该喝就喝前言+后续_阿豪林月周然后续+番外_小说后续在线阅读_无删减免费完结_
  • 陆骁,陆本初小说(陆骁,陆本初)(癫!睁眼穿成老太太挥鞭***逆子)前传+阅读全新作品预订
  • 姐姐含冤而死后冥王另娶,我杀穿整个地府在线阅读_阎罗殿殷红别提一口气完结_小说后续在线阅读_无删减免费完结_
  • (书荒必看)毒后重生:疯王的神医小娇妻沈清歌,萧绝:+后续热血十足
  • 重生后我和太监联手灭了敌国喻辰,林雪续集(重生后我和太监联手灭了敌国)终极反转(喻辰,林雪)全篇一口气阅读
  • 我不做灵媒后,自称灵媒摆渡人的养妹害怕了内容精选_苏晓霍老阿姐无广告_小说后续在线阅读_无删减免费完结_

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1