ホームページ  >  記事  >  ウェブフロントエンド  >  パブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。

パブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。

青灯夜游
青灯夜游転載
2021-06-18 10:32:111883ブラウズ

この記事では、パブリッシュ/サブスクライブ パターンとオブザーバー パターンを紹介し、この 2 つの違いについて説明します。一定の参考値があるので、困っている友達が参考になれば幸いです。

パブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。

少し前に、気まぐれに Promise を一つずつ書いてみました。Promise はたまたまサブスクリプション公開モデルです。仕事で開発に使用している mobx もオブザーバーですどれも使われているものですが、両者の違いについて考えたことがなく、インターネット上の違い分析もわかりにくいです。私自身の要約と最も単純な実装 (シンプルなので理解しやすい) を組み合わせて、この 2 つの理解を共有し、理解を深めます。

#1. 実装のアイデア

arr サブスクライブされたイベントのキャッシュ センターを作成する実行する必要があることを arr キャッシュにプッシュする配列 Middle

    イベントがトリガーされるのを待っているときに、実行イベントを順番に発行します
  • 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.結果

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("面试没通过");
  • 3. 実装結果

eventHub パブリッシュとサブスクライブの 2 つの違い

パブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。on(subscribe ) と発行 (emit)。それらの間には直接的な接続はありません。これらは、中間の arr に依存して、arr に 1 つのプッシュを接続してサブスクライブします。発行時、arr は次のとおりです。順番に実行

##オブザーバー モード

オブザーバーと監視対象の間には関係があります (内部的にはパブリッシュ/サブスクライブ モデルに基づいています)

オブザーバーのインスタンスをパラメーターとしてオブザーバーの Attach メソッドに渡し、オブザーバーの配列にキャッシュします。
  • オブザーバーの setState が呼び出されると、オブザーバーの update メソッドがオブザーバーの配列にキャッシュされます。キャッシュ配列オブザーバーは順番に呼び出されます

プログラミング関連の知識の詳細については、プログラミング ビデオ! を参照してください。 !

以上がパブリッシュ、サブスクライブ、オブザーバーのパターンについて簡単に説明し、それらの違いについて説明しましょう。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。