【JS阅读理解】观察者模式

遇到某个点不通,就多找几个讲解这个点的教程,终究会理解的。

What

什么是观察者模式

概念

  • 正规一点路子的理解:观察者模式是一种设计模式(这不废话么🙄),包含一个对象(叫它"subject "), 用来维持一系列依赖于它(观察者 )的对象,将有关状态的任何变更自动通知给它们。【瞌睡zzz😴】
  • 野路子:张三、李四、王五、周六等等多个人都是(观察者 )炒股的,他们都把个人信息(监听器 )放到了钱多多那。钱多多是个理财经理(目标 ),一有风吹草动就赶紧联系(自动通知)这帮子股民。

关键字整理

一个理财经理(目标),1个或多个股民(观察者),一有变化就发通知

紧急避险Or紧跟风口

钱多多说:"牛市来了,赶紧买进XXX",张三、李四...疯狂行动

突发情况

  • 林林柒作为后来者,同样想找钱多多炒股,怎么办?
  • 周六没赚到钱,就当体验生活的大起大落了,想退出钱多多的客户群体,怎么办?

给钱多多增加、删除客户的能力

小结

钱多多作为一个目标对象("Subject")所具备的能力

  • 通知客户最新动态---Notify
  • 添加新客户---------Add
  • 移除老客户---------Remove

炒股客户们具备的能力

  • 响应迅速,并积极~😎----Update

How

伪代码实现

仅提供思路,不做具体代码展示。😁【能脑补出来,就是真的会了🦾】

js 复制代码
// 目标-钱多多
class Subject{
    constructor() {
        // 用户手机号列表-数组
    }
    
    Add(){
        // 添加新客户-数组push方法
    }
    
    Remove(){
        // 移除老客户-数组过滤方法,filter等
    }
    
    Notify(){
        // 通知客户具体操作-遍历通知
    }
}

// 观察者-炒股客户
class Observer{
    ...
    Update(){
        // 客户操作-buybuybuy(or no-buy😂)
    }
}

总结优缺点

优点:

  • 目标者与观察者,功能耦合度低,都比较专注于自身的功能;观察者被动接受更新,不用时刻专注于目标的变化,时间上解耦; 【实际业务场景中可改善优化的地方有很多,例如:可以关注轮训,定时器等操作】

缺点:

  • 耦合度虽然大大降低,但是仅仅能通知特定时间,不能细分管控(例如:无法像保姆一般照顾有加,精准把控做饭放调料的使用量)
相关推荐
妙蛙种子3119 分钟前
【Java设计模式 | 创建者模式】 原型模式
java·开发语言·后端·设计模式·原型模式
haierccc34 分钟前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct38 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
阿里嘎多学长40 分钟前
2026-04-12 GitHub 热点项目精选
开发语言·程序员·github·代码托管
Hilaku43 分钟前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
军军君011 小时前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
四千岁1 小时前
Ollama+OpenWebUI 最佳组合:本地大模型可视化交互方案
前端·javascript·后端
写不来代码的草莓熊1 小时前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js
Wect2 小时前
JS手撕:手写Koa中间件与Promise核心特性
前端·javascript·面试
张元清2 小时前
React 文件处理:上传、拖放区与对象 URL
前端·javascript·面试