观察者模式/订阅发布者模式

观察者模式

class Subject {
  constructor(name){
    this.status = '周五'
    this.name = name
    this.observers = []
  }
  attach(ther){
    this.observers.push(ther)
  }
  setStatus(value){
    this.status = value
    this.observers.forEach(item=>{
      item.changeStatus(this)
    })
  }
}

class Observer {
  constructor(name){
    this.name = name
  }
  changeStatus(ther){
    console.log(`${this.name}观察到:${ther.name}的状态${ther.status}`)
  }
}

let miao = new Subject('喵喵miao')
let observerA = new Observer('observerA')
let observerB = new Observer('observerB')

miao.attach(observerA)
miao.attach(observerB)
miao.setStatus('周五下午茶时间到~')
// observerA观察到:喵喵miao的状态周五下午茶时间到~
// observerB观察到:喵喵miao的状态周五下午茶时间到~

订阅发布者模式

let e = {
  _callback:[],
  on(callback){
    this._callback.push(callback)
  },
  emit(value){
    this._callback.forEach(item=>{
      item(value)
    })
  },
}
e.on(function(value){
  console.log('订阅者A:',value) //订阅者A: 周五下午茶时间到~
})
e.on(function(value){
  console.log('订阅者B:',value) //订阅者B: 周五下午茶时间到~
})
e.emit('周五下午茶时间到~')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值