观察者模式中目标对象直接通知观察者,两者存在耦合;发布订阅模式通过事件中心解耦,发布者与订阅者无直接依赖。前者适用于简单通信,后者更适合复杂系统的松耦合设计。

观察者模式和发布订阅模式听起来很像,但在 JavaScript 中它们有本质区别。很多人容易混淆这两个概念,其实理解清楚对构建解耦的前端架构很有帮助。
观察者模式中,一个目标对象(Subject)维护一组观察者(Observer),当目标状态发生变化时,会主动通知所有观察者执行更新。
特点在于:观察者和被观察者是**直接绑定**的,两者存在耦合。
例子:实现简单,适合模块内部通信。
立即学习“Java免费学习笔记(深入)”;
代码示意:
class Subject {
constructor() {
this.observers = [];
}
addObserver(observer) {
this.observers.push(observer);
}
notify() {
this.observers.forEach(observer => observer.update());
}
}
class Observer {
update() {
console.log('收到更新');
}
}
发布订阅模式引入了一个中间角色——事件总线(Event Bus)或调度中心。发布者和订阅者不直接通信,而是通过事件通道传递消息。
核心优势是**完全解耦**:发布者不需要知道谁订阅了,订阅者也不关心谁发布的。
典型场景:代码示意:
class EventEmitter {
constructor() {
this.events = {};
}
on(event, callback) {
if (!this.events[event]) {
this.events[event] = [];
}
this.events[event].push(callback);
}
emit(event, data) {
if (this.events[event]) {
this.events[event].forEach(callback => callback(data));
}
}
}
虽然两种模式都实现了“一对多”的通知机制,但结构不同:
可以理解为:发布订阅是观察者模式的“升级版”,加了一层中介,更适合复杂应用。
基本上就这些。实际开发中,Vue 的 $emit/$on、Node.js 的 EventEmitter 都是发布订阅的应用。选择哪种,取决于你是否需要解耦和扩展性。
以上就是JavaScript观察者模式与发布订阅的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号