观察者模式

半城伤御伤魂 提交于 2019-12-19 05:33:30
  • 发布&订阅
  • 一对多

举例一:

//主题,保存状态,状态变化后触发所有观察者对象
class Subject {
    constructor() {
        this.state = 0;
        this.observers = [];
    }

    getState() {
        return this.state;
    }

    setState(state) {
        this.state = state;
        this.notifyAllObservers();
    }
    notifyAllObservers() {
        this.observers.forEach(observer => {
            observer.update();
        })
    }

    attach(observer) {
        this.observers.push(observer);
    }
}

//观察者
class Observer {
    constructor(name, subject) {
        this.name = name;
        this.subject = subject;
        //塞入当前的观察者
        this.subject.attach(this);
    }

    update() {
        console.log(`${this.name} ==== ${this.subject.getState()}`);
    }
}

let s = new Subject();

let o1 = new Observer('o1', s);
let o2 = new Observer('o2', s);
let o3 = new Observer('o3', s);

s.setState(66);
s.setState(88);
// o1 ==== 66
// o2 ==== 66
// o3 ==== 66
// o1 ==== 88
// o2 ==== 88
// o3 ==== 88

其它例子:

  • 网页事件绑定,页面中的事件监听机制大部分都用的观察者模式。
  • Promise
  • jQuery callbacks
  • nodejs自定义事件
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!