观察者模式通过主题与观察者解耦实现状态自动通知,JavaScript中可用于事件处理与数据绑定。

观察者模式是一种设计模式,用于在对象之间定义一对多的依赖关系,当一个对象的状态发生变化时,所有依赖它的对象都会自动收到通知。在JavaScript中,这种模式常用于事件处理、数据绑定等场景。下面是一个简洁而实用的观察者模式实现。
观察者模式包含两个主要角色:
以下是一个基于类的JavaScript实现:
class Subject {
constructor() {
this.observers = [];
}
// 添加观察者
addObserver(observer) {
if (typeof observer.update === 'function') {
this.observers.push(observer);
}
}
// 移除观察者
removeObserver(observer) {
this.observers = this.observers.filter(obs => obs !== observer);
}
// 通知所有观察者
notify(data) {
this.observers.forEach(observer => observer.update(data));
}
}
// 观察者类(可选,只是一个有update方法的对象)
class Observer {
constructor(name) {
this.name = name;
}
update(data) {
console.log(`${this.name} received:`, data);
}
}
下面是具体的调用方式:
立即学习“Java免费学习笔记(深入)”;
// 创建主题
const subject = new Subject();
// 创建观察者
const observer1 = new Observer('Observer 1');
const observer2 = new Observer('Observer 2');
// 注册观察者
subject.addObserver(observer1);
subject.addObserver(observer2);
// 发布通知
subject.notify('Hello from the subject!');
// 可以动态移除
subject.removeObserver(observer1);
subject.notify('Second message');
输出结果为:
Observer 1 received: Hello from the subject! Observer 2 received: Hello from the subject! Observer 2 received: Second message这个模式非常适合用在以下情况:
你可以将Subject扩展为EventEmitter的基础结构,支持不同事件类型、命名事件、once方法等。
基本上就这些。不复杂但很实用。以上就是JavaScript观察者模式实现的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号