我正在尝试创建一个自定义 javascript EventManager 类并添加一些回调函数。但是当回调函数被调用时,函数中的'this'对象是未定义的。我查看了Custom Javascript EventManager - 请帮我完成,但这并不能完全回答我的问题。
为什么 this.onEvent 中 this 和 this.name 未定义?请帮忙,谢谢。
这是我的 jsfiddle:http: //jsfiddle.net/Charissima/fswfv/3/
function arEventManager() {
this.callbacks = {};
this.addCallback = function(eventCategory, fn) {
if (!this.callbacks[eventCategory]) {
this.callbacks[eventCategory] = [];
}
if (fn instanceof Function) {
this.callbacks[eventCategory].push(fn);
}
return this;
}, // addCallback
this.dispatchEvent = function(eventCategory, params) {
// Callback-Funktion(en) ausloesen
for (var iC = 0, lC = this.callbacks[eventCategory].length; iC < lC; iC++) {
console.log( this.callbacks[eventCategory][iC] );
this.callbacks[eventCategory][iC](params);
}
} // dispatchEvent
};
function arPerson() {
this.name;
this.setName = function(name) {
this.name = name;
},
this.getName = function() {
return (this.name);
},
this.onEvent = function(p2) {
alert('this.name = ' + this.name + ' / ' + 'p2.name = ' + p2.name);
}
};
var eventManager = new arEventManager;
var Thomas = new arPerson();
Thomas.setName('Thomas');
var Mike = new arPerson();
Mike.setName('Mike');
eventManager.addCallback("myEvent", Mike.onEvent);
function test() {
eventManager.dispatchEvent('myEvent', Thomas);
}