js シンプルで粗雑なパブリッシュとサブスクライブのサンプルコード

js シンプルで粗雑なパブリッシュとサブスクライブのサンプルコード

パブリッシュ/サブスクライブとは何ですか?

例を挙げてみましょう。あなたは服を買うために店に行きます。あなたと店長はお互いを知りません。店長は自分の服を売るだけで、誰が買うかは気にしません。あなたは欲しい服を買うだけで、どの店が売っているかは気にしません。この時点で、店とあなたはパブリッシュ/サブスクライブの関係を形成します。

店に服のスタイルが並べられたら、欲しい服を探しに行きます。見つかったら買います。見つからなければ、店を出ます。プロセス全体はそれほど簡単です。

使用シナリオ

非同期通信、複数のページ間の通信、ページAのメソッドはページBのメソッドが呼び出されたときに特定の時間にトリガーされる必要がある

コードに直接

クラス Publish {
 コンストラクタ() {
  このリストマップは {} です。
 }
	// サブスクライブ on(key, fn) {
  this.listMap[キー]
   ? this.listMap[キー].push(fn)
   : this.listMap[キー] = [fn];
   
		// サブスクリプションの添字を保存します fn const index = this.listMap[key].length - 1;
  
		// 購読解除関数を返す
  return () => this.clear(key, index);
 }
 
	// このキーへのすべてのサブスクリプションをキャンセルします off(key) {
  this.listMap[キー]を削除します。
 }
 
	// キーで指定されたサブスクリプションをキャンセルする clear(key, index) {
  インデックス === this.listMap[キー].長さ - 1
   ? this.listMap[キー].pop()
   : this.listMap[キー][インデックス] = null;
 }
 
	//一度購読し、トリガー後に自動的に購読を解除する once(key, fn) {
  this.on(キー、(...残り) => {
   fn(...残り);
   this.off(キー);
  });
 }

	// キーを公開
 トリガー(キー、...残り) {
 	if(this.listMapのキー) {
	 	this.listMap[キー].forEach(fn => {
	   fn(...残り);
	  });
 	}
 }
}

使い方

ob = new Publish();

//サブ1を購読する
定数sub1 = ob.on('sub1', (a, b) => {
 コンソールにログ出力します。
});

//サブ1を購読する
定数sub11 = ob.on('sub1', (a, b) => {
 コンソールにログ出力します。
});

ob.trigger('sub1', 2, 3);

// サブ1 から登録解除
サブ1();

// サブ11 から登録解除
サブ11();

//sub3 を購読する
ob.on('sub3', (a, b) => {
 コンソールにログ出力します。
});

//sub3 を購読する
ob.on('sub3', (a, b) => {
 コンソールにログ出力します。
});

ob.trigger('sub3', 6, 7);

// すべてのサブ3から登録解除
ob.off('sub3');

// 一度購読し、自動的に購読解除する ob.once('sub4', (a, b) => {
 コンソールにログ出力します。
});

ob.trigger('sub4', 8, 9);

要約する

js のシンプルで粗雑な公開と購読に関するこの記事はこれで終わりです。より関連性の高い js のシンプルな公開と購読のコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • JavaScript デザイン パターン: オブザーバー パターン (パブリッシャー サブスクライバー パターン)
  • シンプルなサブスクライバーモードとパブリッシャーモードの完全な例の JS モード
  • JavaScript でのパブリッシュ/サブスクライブパターンの簡単な例
  • JavaScript イベント公開/購読モデルの原理と使用法の分析
  • JavaScript の実装とパブリッシュ/サブスクライブ モードの使用に関する詳細な説明
  • js パブリッシュ・サブスクライブモードの例の説明
  • js で実装されたサブスクリプション パブリッシャー モードの簡単な例
  • JavaScript デザインパターン オブザーバーモード(パブリッシュ アンド サブスクライブモード)の原理と実装方法の例
  • [JS マスターロード] デザインパターンシリーズコース - パブリッシャーとサブスクライバーの例 ショッピングカートのリファクタリング
  • js デザイン パターンにおけるプロキシ モードとサブスクリプション パブリッシング モードの詳細な例

<<:  Dockerのインストール方法とDockerの4つのネットワークモードの詳細説明

>>:  MySQL 5.7.10 インストール ドキュメント チュートリアル

推薦する

Vueバックグラウンド管理に多言語機能を追加する例

目次1.まず、main.jsページを設定します2. 対応するパスの下で言語パックを構成します。ここに...

絵文字と問題解決のためのMySQL/Javaサーバーサポートの詳細な説明

この記事では、絵文字用の MySQL Java サーバーのサポートと問題解決方法について説明します。...

ページ内の検索エンジンの呼び出しはBaiduを例に挙げています

今日、突然、自分のウェブページで Google や Baidu のような強力な検索エンジンを呼び出す...

ウェブページのカラーマッチングスキルについての簡単な説明(フロントエンド開発者必読)

一般的に、Web ページの背景色は、より柔らかく、よりシンプルで、より明るく、暗いテキストとマッチし...

And キーワードを使用した MySQL の複数条件クエリ ステートメント

AND キーワードを使用した MySQL 複数条件クエリ。MySQL では、AND キーワードを使用...

MySQL スロークエリログの役割と公開

序文MySQL スロー クエリ ログは、MySQL が提供するログ レコードの一種です。これは、応答...

Vueプロジェクトはログインと登録の効果を実現します

この記事の例では、ログインと登録の効果を実現するためのvueプロジェクトの具体的なコードを共有してい...

CSS3のtransform属性で実装される4つの機能

CSS3 では、transform 関数を使用して、テキストや画像の回転、拡大縮小、傾斜、移動という...

Oracle を MySQL に置き換える際の問題と解決策

目次移行ツールアプリケーション変換mysql8.0 ドライバ パッケージを追加データソース構成の変更...

固定テーブル幅テーブルレイアウト: 固定

テーブルを画面全体(残りの空白領域)に表示するために、幅属性は 100% と定義されることが多く、セ...

MacOS Catalina アップグレード後の VMware ブラック スクリーン問題に対する完璧な解決策の詳細な説明

MacOS Catalina アップグレード後の VMware ブラック スクリーンに対する完璧なソ...

MySQL の主キーがクエリを高速化するために数値を使用するか UUID を使用するかについての簡単な分析

実際の開発では、MySQL の主キーは重複できず、主キーが自動的にインクリメントされることがあります...

Vueは携帯電話のカメラとアルバムを呼び出す機能を実装します

この記事では、携帯電話のカメラとアルバムにアクセスするためのVueの具体的なコードを参考までに共有し...

MySQL インデックスの最適化: ページング探索の詳細な紹介

目次MySQL インデックス最適化ページングの調査ケース1ケース2 MySQL インデックス最適化ペ...

Vue が学ぶべき知識ポイント: forEach() の使用

序文フロントエンド開発では、目的のコンテンツを取得するためにループをトラバースする必要がある状況に頻...