JavaScript设计模式样例十四 —— 观察者模式

观察者模式(Observer Pattern)

定义:当一个对象被修改时,则会自动通知它的依赖对象。
目的:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
场景:一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知,进行广播通知。
class Subject {
    constructor () {
        this.state = 0
        this.observers = []
    }

    getState () {
        return this.state
    }

    setState (state) {
        this.state = state
        this.notifyAllObsevers()
    }

    attach (observer) {
        this.observers.push(observer)
    }

    notifyAllObsevers () {
        for (let ele of this.observers.values()) {
            ele.update()
        }
    }
}

class Observer {
    constructor (name, subject) {
        this.name = name
        this.subject = subject
        this.subject.attach(this)
    }
    update () {
        console.log(this.name,this.subject.getState())
    }
}

let subject = new Subject()
let observer = new Observer('observer 1', subject)
subject.setState('hahaha')

Git地址:https://github.com/skillnull/Design-Mode-Example

posted @   SKILL·NULL  阅读(143)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示