この記事では、パブリッシュ/サブスクライブ パターンとオブザーバー パターンを紹介し、この 2 つの違いについて説明します。一定の参考値があるので、困っている友達が参考になれば幸いです。
少し前に、気まぐれに Promise を一つずつ書いてみました。Promise はたまたまサブスクリプション公開モデルです。仕事で開発に使用している mobx もオブザーバーですどれも使われているものですが、両者の違いについて考えたことがなく、インターネット上の違い分析もわかりにくいです。私自身の要約と最も単純な実装 (シンプルなので理解しやすい) を組み合わせて、この 2 つの理解を共有し、理解を深めます。
arr サブスクライブされたイベントのキャッシュ センターを作成する実行する必要があることを arr キャッシュにプッシュする配列 Middle
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.結果
2回公開しましたが、外部条件により最終的に上のコンソールは1回しか実行されませんでした##オブザーバー モード
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("面试没通过");
eventHub パブリッシュとサブスクライブの 2 つの違い
on(subscribe ) と発行 (emit)。それらの間には直接的な接続はありません。これらは、中間の arr に依存して、arr に 1 つのプッシュを接続してサブスクライブします。発行時、arr は次のとおりです。順番に実行
以上がパブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。