本篇文章给大家介绍一下发布订阅和观察者模式,聊聊两者的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

前段时间心血来潮自己写一一个promise, promise刚好就是订阅发布模式,工作中开发用的mobx 整体又是观察者模式,虽然都用,但一直没去细想两者的差异,网上的区别分析看的云里雾里。结合一下 整理一篇自己的总结和最简单实现(也因为简单 所以也很好理解)做个分享同时加深自己对这两者的理解
1、实现思路
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、实现思路
与观察者模式类似,但需要分一个观察者,和被观察者
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、实现结果
更多编程相关知识,请访问:编程视频!!
以上就是浅谈发布订阅和观察者模式,聊聊两者的区别的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号