设计模式 ~ 观察者模式

概念

观察者模式是一种设计模式,也被称为发布-订阅模式或事件模式;

用于在对象之间建立一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新;

~

如:DOM事件、vue / React 生命周期、各种异步回调 ~ 定时器、Promise.then、nodeJs 流式读取、端口监听

代码演示

存在两个角色:主题(Subject )和观察者(Observer ):

主题是被观察对象,它维护一组观察者对象并通知它们;

观察者是依赖于主题的对象,它们注册自己到主题以便于主题状态改变接收通知,并执行响应操作;

Subject: 可以理解为饮品店的吧台,当完成会通知你去拿取

javascript 复制代码
class Subject {
  private state: number = 0 // 状态
  private observers: Observer[] = [] // 观察者们
  // 获取状态
  getState(): number {
    return this.state
  }
  // 设置状态
  setState(newState: number) {
    this.state = newState
    this.notify() // 通知
  }
  // 添加观察者
  attach(observer: Observer) {
    this.observers.push(observer)
  }
  // 通知
  private notify() {
    this.observers.forEach(observer => {
      observer.update(this.state)
    })
  }
}

Observer : 可以理解为饮品店的顾客,等待吧台的通知

javascript 复制代码
class Observer {
  name: string
  constructor(name: string) {
    this.name = name
  }
  // 通知
  update(state: number) {
    console.log(`${this.name} updated, state is ${state}`)
  }
}

创建观察者对象

javascript 复制代码
const sub = new Subject()
const observer1 = new Observer('A')
const observer2 = new Observer('B')
sub.attach(observer1)
sub.attach(observer2)
sub.setState(1)

UML类图

~ 1:n 表示 1对多,一个主题对应多个观察者

VUE

vue 中的观察者模式:watch、watchEffect、包括组件更新过程

Watcher:监听器 ~ 监听 data 、当 data发生更新触发 re-render(重新渲染)

相关推荐
killerbasd15 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
橘子编程16 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
叫我一声阿雷吧17 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰17 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong2317 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
天若有情67318 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
yuki_uix19 小时前
重排、重绘与合成——浏览器渲染性能的底层逻辑
前端·javascript·面试
止观止19 小时前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
时寒的笔记19 小时前
js逆向7_案例惠nong网
android·开发语言·javascript
吴声子夜歌19 小时前
ES6——Generator函数详解
前端·javascript·es6