JavaScript简单手写观察者模式

Posted 七度丢失的梦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript简单手写观察者模式相关的知识,希望对你有一定的参考价值。

有的人把发布 订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知。

其实他们还是有差别的,在发布订阅模式中,组件是松散耦合的,正好和观察者模式相反

发布订阅模式中,发布者和订阅者不知道对方的存在。它们只有通过消息代理进行通信。

在观察者模式中,观察者(订阅)是知道被观察者(发布)的,被观察者也一直保持对观察者进行记录。

下面就来看一下观察者的简单实现↓

// 被观察者
class Subject {
    constructor(name){
        this.name
        this.observers = [] // 观察者 存放在被观察者中
        this.state = ‘停电了,灯不亮‘
    }
    // 被观察者要提供一个接受观察者的方法
    attach(observer) {
        this.observers.push(observer) // 存放所有观察者
    }
    setState(newState) { // 改变被观察着的状态
        this.state = newState
        this.observers.forEach(o=>o.update(newState))
    }
}
// 观察者
class Observer{
    constructor(name) {
        this.name = name
    }
    update(newState){ //用来通知所有的观察者状态更新了
        console.log(this.name+‘说:‘+newState)
    }
}
// 被观察者 灯
let sub = new Subject(‘灯‘)
let mm = new Observer(‘小明‘)
let jj = new Observer(‘小健‘)

// 订阅 观察者
sub.attach(mm)
sub.attach(jj)

sub.setState(‘灯亮了来电了‘)
// 小明说:灯亮了来电了
// 小健说:灯亮了来电了

 

 

以上是关于JavaScript简单手写观察者模式的主要内容,如果未能解决你的问题,请参考以下文章

手写简单的观察者模式

手写简单的观察者模式

从一道面试题简单谈谈发布订阅和观察者模式

考验手写!透析观察者模式和发布订阅模式

手写观察者模式

手写实现简单的Vue事件总线