/*Decorator.js*/
var util = require("util);
var Base = require('./Base');
function Decorator(){
Base.call(this);
this.dosomething = function(){
Base.dosomething();
console.log('I am a decorator');//拓展内容
}
}
util.inherits(Decorator, Base);//继承
module.exports = Decorator;
4. 观察者模式
什么是观察者模式呢?举个例子吧~小狗同学和小熊同学同时喜欢上了班里可爱的小兔同学。小狗和小熊都会注意着小兔的一举一动,只有小兔有什么动静他们两个都会知道~相对而言呢,小狗和小熊就是小兔的"观察者",而小兔呢就是"被观察的对象"。比较重要的是:小兔发生的动静(某个函数),会同时通知到观察者小狗和小熊,让他们两个也会做出相应的反馈(各自的回调函数)
/*被观察者*/
module.exports = function(){
var m_obserSet = [];//观察者列表
var _self = this;
this.addObser = function(observer){
m_obserSet.push(observer);//添加观察者
}
this.doAction = function(){
console.log("Observable do some action");
_self.notifyAllObeser();
}
this.notifyAllObeser = function(){//发生动作
for(var key in m_obserSet){//逐个通知观察者
m_obserSet[key].update();//观察者执行回调
}
}
}