观察者模式浅析

//儿子
class mySon {
  constructor(name) {
    this.name = name;
    this.status = "笑了";
    this.arr = [];
  }
  //将家长插入监控组
  attach(item) {
    debugger
    this.arr.push(item);
  }
  changeStatus(newStatus) {
    if (newStatus !== this.status) { //变化状态
      this.status = newStatus;
      this.arr.forEach(item => {
        item.updateStatus(newStatus);
      })
    }
  }
}
//家长
class obServer {
  constructor(name) {
    this.name = name;
  }
  updateStatus(status) {
    console.log(this.name + " 接受到了儿子的状态变化:" + status);
  }
}
let dada = new obServer("吧吧");
let mom = new obServer("妈妈");
let grandfather = new obServer("爷爷");

let son = new mySon("儿子");
son.attach(dada);
son.attach(mom);
son.attach(grandfather);
son.changeStatus("da 了");

这个简单的模型从本质上来说还是callback的应用,
1.将监视人加入到儿子的监控人组里
2.当状态发生变化的时候 循环调用监控人组里的监控方法即可实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值