以下是代码,以及我的理解。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的作用
添加回答
举报
0/150
提交
取消