以下是代码,以及我的理解。
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的作用
达令说
相关分类