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

观察者模式

  • 观察者被观察者 进行注册,将观察者加入观察者 队列
  • 被观察者发起 事件 ,调用观察者提供的方法
class Subject{
    constructor() {
        this.subscriberList = []
    }

    addSubscriber(subscriber) {
        this.subscriberList.push(subscriber)
    }

    notifyAllSubscribers(data) {
        this.subscriberList.forEach(subscriber => {
            subscriber.update(data)
        })
    }
}

class Observer{
    constructor(name){
        this.name = name
    }

    update(data) {
        console.log(`${this.name} received data: ${data}`)
    }
}

const subject = new Subject()
const observer1 = new Observer('Observer 1')
const observer2 = new Observer('Observer 2')

subject.addSubscriber(observer1)
subject.addSubscriber(observer2)

subject.notifyAllSubscribers('hello')

发布订阅模式

  • 订阅者事件中心 订阅 事件
  • 发布者实践中心 发布(触发) 事件
  • 事件中心 调用相对应的 事件
class EventEmitter {
    constructor() {
        this.events = {}
    }

    emit(event,data){
        this.events[event]?.forEach(callback => callback(data))
    }

    on(event,callback){
        this.events[event] = [...(this.events[event] || []),callback]
    }
}

const ee = new EventEmitter()

ee.on('event1',function(data){
    console.log(data,1);
})
ee.on('event1',function(data){
    console.log(data,2);
})

ee.emit('event1','hello')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值