设计模式:发布订阅模式

Posted 乱舞春秋__

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了设计模式:发布订阅模式相关的知识,希望对你有一定的参考价值。

调度中心

class Center {
      constructor () {
        this.message = {}
      }

      //订阅
      on (type, fn) {
        if (this.message[type] === undefined) {
          this.message[type] = []
        }
        this.message[type].push(fn)
      }

      //取消订阅
      off (type, fn) {
        if (this.message[type] === undefined) throw Error('未订阅此事件')
        if (!fn) return delete this.message[type] 
        this.message[type] = this.message[type].filter(item => item !== fn)
      }

      //触发
      emit (type) {
        if (this.message[type] === undefined) return
        this.message[type].forEach(item => {
          item()
        })
      }
    }

相关方法

订阅

  • 订阅者可以在调度中心订阅一系列事件
on (type, fn) {
        if (this.message[type] === undefined) {
          this.message[type] = []
        }
        this.message[type].push(fn)
      }

取消订阅

  • 订阅者可以取消事件的全部处理函数
  • 订阅者也可以取消事件的某个处理函数
  • 当取消未被订阅的事件时,就会抛出错误
off (type, fn) {
        if (this.message[type] === undefined) throw Error('未订阅此事件')
        if (!fn) return delete this.message[type] 
        this.message[type] = this.message[type].filter(item => item !== fn)
      }

触发

emit (type) {
        if (this.message[type] === undefined) return
        this.message[type].forEach(item => {
          item()
        })
      }

示例

  • 实例化调度中心
    const center = new Center()
  • 订阅a, b, c 三个事件
	center.on('a', handler1)
    center.on('a', handler2)
    center.on('b', handler3)
    center.on('b', handler4)
    center.on('c', handler5)
    center.on('c', handler6)
    function handler1 () { console.log('handler1') }
    function handler2 () { console.log('handler2') }
    function handler3 () { console.log('handler3') }
    function handler4 () { console.log('handler4') }
    function handler5 () { console.log('handler5') }
    function handler6 () { console.log('handler6') }
  • 取消订阅事件a的所有处理函数
center.off('a')
  • 取消事件a 的处理函数handler2
center.off('a', handler2)
  • 触发事件 a
center.emit('a')

以上是关于设计模式:发布订阅模式的主要内容,如果未能解决你的问题,请参考以下文章

EventBus发布-订阅模式 ( Android 中使用 发布-订阅模式 进行通信 )

从发布-订阅模式到消息队列

订阅发布模式概念基础

《 javascript 设计模式与开发实践 》 ---发布-订阅模式 代码小问题

ActiveMQ入门系列三:发布/订阅模式

JS 设计模式八 -- 发布订阅者模式