设计模式 ~ 发布订阅者

发表订阅者模式

用于实现对象之间的松耦合通信;

在该模式中,存在一个或多个发布者(Publishers)和一个或多个订阅者(Subscribers);

发布者负责发布消息,而订阅者负责订阅感兴趣的消息并在接收到消息时做出相应的处理。

对比观察者模式

Subject 和 Observer 直接绑定,中间无媒介;

Publisher 和 Observer 相互不认识,中间有媒介;

代码演示

javascript 复制代码
function PubSub() {
  this.subscribers = {}
}

subscribe 方法,订阅者可以注册自己来接收特定事件的通知;

unsubscribe 方法,订阅者可以取消对特定事件的订阅;

publish 方法,发布者可以发布特定事件及其相关的数据。

javascript 复制代码
PubSub.prototype = {
  subscribe: function (event, callback) {
    if (!this.subscribers[event]) {
      this.subscribers[event] = []
    }
    this.subscribers[event].push(callback)
  },
  unsubscribe: function (event, callback) {
    if (this.subscribers[event]) {
      var index = this.subscribers[event].indexOf(callback)
      if (index !== -1) {
        this.subscribers[event].splice(index, 1)
      }
    }
  },
  publish: function (event, data) {
    if (this.subscribers[event]) {
      this.subscribers[event].forEach(function (callback) {
        callback(data)
      })
    }
  }
}

创建实例

javascript 复制代码
const pubsub = new PubSub()

订阅

javascript 复制代码
pubsub.subscribe('message', function (data) {
  console.log('收到消息:', data)
})

发布

javascript 复制代码
pubsub.publish('message', '发布消息 ~~~')

VUE

Vue2 实例本身就支持自定义事件,但 Vue3 不再支持;

推荐使用 mitt ,文档 https://github.com/developit/mitt

mitt 没有 once ,也可以使用 event-emitter https://www.npmjs.com/package/event-emitter

创建单独的 .js 文件、保证单例性

javascript 复制代码
import mitt from 'mitt'
const emitter = mitt() // 单例
export default emitter

发布和订阅

javascript 复制代码
emitter.on('change', () => {
    console.log('change')
})
emitter.emit('change')

即时销毁

javascript 复制代码
created() {
    emitter.on('change', this.fn)
},
beforeUnmount() {
    emitter.off('change', this.fn)
}
相关推荐
晓风残月淡10 小时前
系统架构设计师:设计模式——结构型设计模式
设计模式·系统架构
Wabi_sabi_x11 小时前
C++设计模式:面向对象的八大设计原则之一
开发语言·c++·设计模式
智驾15 小时前
C++,设计模式,【建造者模式】
c++·设计模式·建造者模式
Wabi_sabi_x16 小时前
C++设计模式:面向对象的八大设计原则之三
开发语言·c++·设计模式
Wabi_sabi_x20 小时前
C++设计模式:面向对象的八大设计原则之四
开发语言·c++·设计模式
jz_ddk1 天前
[方法论]软件工程中的设计模式:从理论到实践的深度解析
设计模式·软件工程
wjm0410061 天前
C++八股--5--设计模式--适配器模式,代理模式,观察者模式
c++·设计模式·适配器模式
wjm0410061 天前
C++八股--three day --设计模式之单例和工厂
c++·单例模式·设计模式
晓风残月淡2 天前
系统架构设计师:设计模式——创建型设计模式
设计模式·系统架构
YoseZang2 天前
【设计模式】GoF设计模式之备忘录模式(Memento Pattern)
设计模式·备忘录模式