浅谈发布订阅和观察者模式,聊聊两者的区别

发布时间:2022-05-16 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了浅谈发布订阅和观察者模式,聊聊两者的区别脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
本篇文章给大家介绍一下发布订阅和观察者模式,聊聊两者的区别。有一定的参考价值有需要的朋友可以参考一下希望对大家有所帮助

前段时间心血来潮自己写一一个promise, PRomise刚好就是订阅发布模式,工作中开发用的mobx 整体又是观察者模式,虽然都用,但一直没去细想两者的差异,网上的区别分析看的里雾里。结合一下 整理一篇自己的总结和最简单实现(也因为简单 所以也很好理解)做个分享同时加深自己对这两者的理解

订阅发布

1、实现思路

  • arr 做订阅了的事件的缓存中心@H_304_16@
  • 通过过on把需要做的事push arr 缓存数组中
  • 等待事件触发时 依次emIT执行事件

2、代码实现

interface eventHub {
  arr: Array<Function>;
  on(fn: Function): void;
  emit(): void;
}
interface PErson {
  age: number;
  name: string;
}
let eventHub: eventHub = {
  arr: [] as Array<Function>,
  // 订阅
  on(fn: Function) {
    this.arr.push(fn);
  },
  //   发布
  emit() {
    this.arr.foreach((fn) => fn());
  },
};
let person: Person = {} as Person;
eventHub.on(() => {
//订阅的事件里判断当 person长度为2时 打印person,
  if (Object.keys(person).length == 2) {
    console.LOG(person);
  }
});
setTimeout(function () {
  person.age = 27;
  //发布的时候去遍历 this.arr 并执行第一次
  eventHub.emit();
}, 10);
setTimeout(function () {
  person.name = "Zoe";
  //发布的时候去遍历 this.arr 并执行第二次
  eventHub.emit();
}, 20);

3、结果

虽然发布了两次 但最终on 里的console因为外部条件只执行了一次

1.gif

观察者模式

1、实现思路

与观察者模式类似,但需要分一个观察者,和被观察者

  • 观察者和被观察者存在关联,(内部基于发布订阅模式)

2、代码实现

// 被观察者
class Subject {
  name: string; //实例上定义一个name属性
  state: string;
  observers: any[];
  constructor(name:string) {
    this.name = name;
    this.observers = [];
    this.state = "";
  }
  attach(o) {
    //传入观察者
    this.observers.push(o);
  }
  setState(newState) {
    this.state = newState;
    this.observers.forEach((o) => o.update(this));
  }
}
// 观察者
class Observer {
  name: string;
  constructor(name) {
    this.name = name;
  }
  update(interviewee) {
    console.log(`${interviewee.name} say to: ${this.name} ZOE的${interviewee.state}`);
  }
}
let hr = new Subject("HR");
let observer1 = new Observer("内推者");
let observer2 = new Observer("面试者");
hr.attach(observer1);
hr.attach(observer2);
hr.setState("面试通过了");
// baby.setState("面试没通过");

3、实现结果

image.png

两者的区别

eventHub 发布订阅

  • on(订阅)和发布(emit)之间没有直接联系,是依赖中间的arr 做衔接 订阅一个push 到arr一个,emit的时候依次执行arr

观察者模式

  • 观察者和被观察者存在关联,(内部基于发布订阅模式)
  • 将观察者的实例作参数 传入被观察者的attach方法中 并缓存在observers 数组中
  • 当观察者setState时候 依次调用缓存数组observers 中观察者的update方法

更多编程相关知识,请访问:编程视频!!

以上就是浅谈发布订阅和观察者模式,聊聊两者的区别的详细内容,更多请关注脚本宝典其它相关文章!

脚本宝典总结

以上是脚本宝典为你收集整理的浅谈发布订阅和观察者模式,聊聊两者的区别全部内容,希望文章能够帮你解决浅谈发布订阅和观察者模式,聊聊两者的区别所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: