基本的にMVCはオブザーバーパターンに基づいています(そしてコントローラーも)
Javascript内にオブザーバーを実装するにはどうすればよいですか?
function Observer() {
var subscribers = [];
return {
subscribe: function(eventName, object) {
subscribers.push({ event: eventName, target: object });
},
unsubscribe: function(object) {
var indexToDelete = subscribers.indexOf(object);
subscribers.splice(indexToDelete, 1);
},
trigger: function(eventName, p1, p2, p3, p4, p5) {
for (var i = 0; i < subscribers.lenght; i++) {
if (subscribers[i].event == eventName) {
//target object must implement this function
subscribers[i].target[eventName](p1, p2, p3, p4, p5);
}
}
}
}
}
そして、どのようにそれを使用することができますか?
var model = {
fireChangesInsideOfModel: function(p1){
//do some model update logic here
}
}
var controller = Observer();
controller.subscribe("fireChangesInsideOfModel", model);
controller.trigger("fireChangesInsideOfModel", 11231); // 11231 - is an example of a parameter
これがお役に立てば幸いです。