js デザイン パターン: コマンド パターンとは何ですか? jsコマンドモードの概要
この記事では、JS デザイン パターンに関するコンテンツをお届けします: コマンド パターンとは何ですか? js コマンド モードの紹介は、参考にしていただければ幸いです。
コマンドモードとは何ですか?
定義: リクエストをオブジェクトにカプセル化し、さまざまなリクエストでクライアントをパラメータ化できるようにします。
主な解決策: ソフトウェア システムでは、動作要求者と動作実装者は通常、密結合した関係を持ちますが、場合によっては、動作の記録、元に戻す、またはやり直し、トランザクションなどが必要になる場合もあります。この種の密結合変化に耐えられないデザインは不向きです。
いつ使用するか: 「記録、元に戻す/やり直し、トランザクション」やその他の動作の処理などの状況によっては、変更に抵抗できないこの種の密結合は不適切です。この場合、「動作要求者」と「動作実装者」をどのように分離すればよいでしょうか?一連の動作をオブジェクトに抽象化すると、それらの間の疎結合を実現できます。
解決方法: 発信者経由で受信者を呼び出し、発信者→受信者→コマンドの順序でコマンドを実行します。
キーコード: 3つの役割を定義: 1. 受信した実際のコマンド実行オブジェクト 2. コマンド 3. 呼び出し者はコマンドオブジェクトの入り口を使用します
js コマンドモードの利点: 1. システムの結合を軽減します。 2. 新しいコマンドをシステムに簡単に追加できます。
js コマンド モードの欠点: コマンド モードを使用すると、一部のシステムでは特定のコマンドが多すぎる可能性があります。
js コマンド モードの使用シナリオ: コマンド モードは、コマンドが考慮される場所であればどこでも使用できます。例: 1. GUI のすべてのボタンはコマンドです。 2. CMD をシミュレートします。
注: システムはコマンドの元に戻す (Undo) 操作と回復 (Redo) 操作をサポートする必要があります。 コマンド モードの拡張を参照してください。
js コマンド モード
コマンド モードも JavaScript では比較的単純です。按钮
和命令
は次のコードで抽出されるため、コマンド モードを複雑なプロジェクトで使用して、インターフェイス コードと関数コードをさまざまな人々に提供して作成することができます。
const setCommand = function(button, command) { button.onClick = function() { command.excute() } } // -------------------- 上面的界面逻辑由A完成,下面的由B完成 const menu = { updateMenu: function() { console.log('更新菜单') }, } const UpdateCommand = function(receive) { return { excute: receive.updateMenu, } } const updateCommand = UpdateCommand(menu) // 创建命令 const button1 = document.getElementById('button1') setCommand(button1, updateCommand)
関連する推奨事項:
js デザイン パターン: オブザーバー パターン (パブリッシュ/サブスクライブ パターン) とは何ですか? JS オブザーバー パターンの紹介
js デザイン パターン: イテレーター パターンとは何ですか? JS イテレータ パターンの紹介
以上がjs デザイン パターン: コマンド パターンとは何ですか? jsコマンドモードの概要の詳細内容です。詳細については、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)

ホットトピック









記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

この記事では、ソースマップを使用して、元のコードにマッピングすることにより、Minified JavaScriptをデバッグする方法について説明します。ソースマップの有効化、ブレークポイントの設定、Chrome DevtoolsやWebpackなどのツールの使用について説明します。

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...
