Nodeのイベントモジュールの簡単な分析
vue プロジェクトでは、コンポーネント間の通信を管理するためにグローバル イベント バスを使用することがあります。 vue2 プロジェクトでは、$emit
、$on
、および $off
を使用して、vue3 の eventHub
; ## をカプセル化できます。 #$on と
$off が削除され、mitt ライブラリまたは tiny-emitter ライブラリを使用できます。ノードには、イベントの監視と発行に役立つイベント モジュールが組み込まれているため、それほど面倒な作業は必要ありません。
イベントの監視と発行
最初に CommonJS 構文を使用してEventEmitter クラスをインポートし、次にインスタンス
emitter を生成します。 (
EventEmitter は非常に重要です。たとえば、後続の記事で紹介する
stream は
EventEmitter のインスタンスです):
const EventEmitter = require('events') const emitter = new EventEmitter()
emitter .on() を使用してイベントを監視します。渡される最初のパラメータはイベント名です。2 番目のパラメータは、発行されるイベントをリッスンした後に実行されるコールバックです。イベントを発行するときにパラメーターが渡されます。コールバック関数の場合は、1 つずつ取得することも、次のように
関数の残りのパラメーターを使用することもできます。 [推奨関連チュートリアル: nodejs ビデオ チュートリアル, プログラミング教育]// 监听事件
emitter.on('test', (...args) => {
console.log(args) // [ 1, 2, 3 ]
})
// 发射事件
emitter.emit('test', 1, 2, 3)
: を使用できます。 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>emitter.once(&#39;test&#39;, () => {
console.log(&#39;监听到了事件发射&#39;)
})
emitter.emit(&#39;test&#39;)
emitter.emit(&#39;test&#39;) // 本次发射不会触发打印</pre><div class="contentsignin">ログイン後にコピー</div></div>
次の例に示すように、イベントを監視する場所が複数ある場合イベントが発行されると、リスニング コールバックが順番にトリガーされます:
emitter.on('test', () => { console.log('监听到了事件发射,1') }) emitter.on('test', () => { console.log('监听到了事件发射,2') }) emitter.emit('test')
実行結果:
リッスン イベントを前面に追加したい場合は、
(または emitter.prependOnceListener()
) を使用できます。事前にリッスンしますが、一度だけリッスンします): <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>emitter.on(&#39;test&#39;, () => {
console.log(&#39;监听到了事件发射,1&#39;)
})
emitter.prependListener(&#39;test&#39;, () => {
console.log(&#39;监听到了事件发射,2&#39;)
})
emitter.emit(&#39;test&#39;)</pre><div class="contentsignin">ログイン後にコピー</div></div>
現在の結果は次のとおりです:
emitter.off()
(または emitter.removeListener ()
) を使用してイベントの監視を削除できますが、対応するイベント名とコールバックを渡す必要があります。したがって、監視時のコールバックは、上記のように emitter.on()## で直接定義できません # 内部。外部で定義し、コールバックへの参照を渡す必要があります:
function handler(...args) { console.log(args) // [ 1, 2, 3 ] } emitter.on('test', handler) emitter.emit('test', 1, 2, 3) emitter.off('test', handler) emitter.emit('test', '无法被监听到')
emitter.off() 削除できるリスナーは 1 つだけであり、リスナー コールバックを渡す必要があります。複数のリスナーがあり、それらをすべて削除したい場合は、emitter.removeAllListeners() を使用できます。 :
emitter.on('test', handler) emitter.on('test', handler) emitter.on('test', handler) emitter.removeAllListeners()
emitter.removeAllListeners()パラメータが渡されない場合は、すべてのイベント名のすべてのイベント リスナーを削除します。イベント名を渡すこともでき、そのイベント名に対応するすべてのイベント リスナーが削除されます。 その他のメソッド
リスナー数の制限
1 EventEmitter オブジェクト、イベント名の最大リスナー数のデフォルトは 10 です。これは、emitter.getMaxListeners()
:console.log(emitter.getMaxListeners()) // 10
で確認できます。たとえば、11 回と書かれています。
emitter .on('test ', handler) を実行すると、エラーが報告され、emitter.setMaxListeners() を使用して最大制限を増やすよう求められます:
現在の EventEmitter オブジェクト上の特定のイベント名にリスナーがいくつあるか、およびそれが最大制限を超えているかどうかを知りたい場合は、emitter.listenerCount()
console.log(emitter.listenerCount('test'))
イベント名とリスナーを取得しますUse emitter.eventNames()
現在の EventEmitter オブジェクトに登録されているすべてのイベント名と、イベント文字列で構成される返された配列を取得するには:emitter.on('test1', handler) emitter.on('test2', handler) console.log(emitter.eventNames()) // [ 'test1', 'test2' ]
イベントに対応するすべてのリスナーを取得したい場合は、
emitter.listeners を使用できます。 () を入力し、イベント名を渡します: function handler1() {} function handler2() {} emitter.on('test', handler1) emitter.on('test', handler2) console.log(emitter.listeners('test'))
得られた結果は次のとおりです:
ノード関連の知識の詳細については、次のサイトを参照してください。 : nodejs チュートリアル
以上がNodeのイベントモジュールの簡単な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Node.js は、高いパフォーマンス、スケーラビリティ、クロスプラットフォーム サポート、豊富なエコシステム、開発の容易さなどの機能を備えているため、バックエンド フレームワークとして使用できます。

MySQL データベースに接続するには、次の手順に従う必要があります。 mysql2 ドライバーをインストールします。 mysql2.createConnection() を使用して、ホスト アドレス、ポート、ユーザー名、パスワード、データベース名を含む接続オブジェクトを作成します。 connection.query() を使用してクエリを実行します。最後に connection.end() を使用して接続を終了します。

Node.js インストール ディレクトリには、npm と npm.cmd という 2 つの npm 関連ファイルがあります。違いは次のとおりです。拡張子が異なります。npm は実行可能ファイルで、npm.cmd はコマンド ウィンドウのショートカットです。 Windows ユーザー: npm.cmd はコマンド プロンプトから使用できますが、npm はコマンド ラインからのみ実行できます。互換性: npm.cmd は Windows システムに固有ですが、npm はクロスプラットフォームで使用できます。使用上の推奨事項: Windows ユーザーは npm.cmd を使用し、他のオペレーティング システムは npm を使用します。

Node.js には次のグローバル変数が存在します。 グローバル オブジェクト: グローバル コア モジュール: プロセス、コンソール、require ランタイム環境変数: __dirname、__filename、__line、__column 定数: unknown、null、NaN、Infinity、-Infinity

Node.js と Java の主な違いは、設計と機能です。 イベント駆動型とスレッド駆動型: Node.js はイベント駆動型で、Java はスレッド駆動型です。シングルスレッドとマルチスレッド: Node.js はシングルスレッドのイベント ループを使用し、Java はマルチスレッド アーキテクチャを使用します。ランタイム環境: Node.js は V8 JavaScript エンジン上で実行され、Java は JVM 上で実行されます。構文: Node.js は JavaScript 構文を使用し、Java は Java 構文を使用します。目的: Node.js は I/O 集中型のタスクに適しており、Java は大規模なエンタープライズ アプリケーションに適しています。

ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

はい、Node.js はバックエンド開発言語です。これは、サーバー側のビジネス ロジックの処理、データベース接続の管理、API の提供などのバックエンド開発に使用されます。

Node.js プロジェクトのサーバー デプロイメント手順: デプロイメント環境を準備します。サーバー アクセスの取得、Node.js のインストール、Git リポジトリのセットアップ。アプリケーションをビルドする: npm run build を使用して、デプロイ可能なコードと依存関係を生成します。コードをサーバーにアップロードします: Git またはファイル転送プロトコル経由。依存関係をインストールする: サーバーに SSH で接続し、npm install を使用してアプリケーションの依存関係をインストールします。アプリケーションを開始します。node Index.js などのコマンドを使用してアプリケーションを開始するか、pm2 などのプロセス マネージャーを使用します。リバース プロキシの構成 (オプション): Nginx や Apache などのリバース プロキシを使用して、トラフィックをアプリケーションにルーティングします。
