为了账号安全,请及时绑定邮箱和手机立即绑定

关于事件代理的一些疑问?

关于事件代理的一些疑问?

肥皂起泡泡 2019-02-20 18:17:58
以下是代码,以及我的理解。function addEvent(element, event, listener) {   if(element.addEventListener){       element.addEventListener(event,listener,false)   }   else if(element.attachEvent()){       element.attachEvent("on"+event,listener)   }   else{       event["on"+event]=listener;   }}function delegateEvents(element,tag,eventName,listener){   addEvent(element,eventName, function(event){       if (event.target&&event.target.nodeName.toLowerCase()==tag) {           listener.call(event.target,event);//listener();       }   });}//首先定义一个函数 delegateEvent();传入四个参数,对象,对象的子集,事件名,响应函数;//要为对象添加一个事件,然后传入需要的参数。这里传入的是对象,事件名,一个需要判断的函数;(最后还是,listener)//这个函数需要判断,先找到事件源的对象然后判断是不是对象的那个子集。如果是用call将响应函数给事件给事件源对象,event作为参数传入。//通过冒泡,最后会传给需要实现的父级对象。我的疑问是这里为什么一定要用,call。 //listener.call(event.target,event);我自己写的时候加了个listener(event)就完了。但我看他们的代码都有call;没理解call的作用
查看完整描述

1 回答

?
达令说

TA贡献1821条经验 获得超6个赞

call,改变了函数内的作用域,this的值
不用call,this为window

查看完整回答
反对 回复 2019-02-23
  • 1 回答
  • 0 关注
  • 344 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信