JavaScriptを深く理解するシリーズ(29):デザインパターンのデコレータパターンを詳しく解説_JavaScriptスキル
はじめに
デコレータは、継承に対するより柔軟な代替手段を提供します。 デコレーターを使用すると、同じインターフェースでオブジェクトをラップすることができます。これにより、メソッドに動作を追加できるだけでなく、元のオブジェクト (デコレーターのコンストラクターなど) によって呼び出されるメソッドを設定することもできます。
デコレータは、オーバーロードされたメソッドの形式で新しい関数を追加するために使用され、特定の目的を達成するためにデコレータの前後に独自の動作を追加できます。
テキスト
それでは、デコレータ パターンの利点は何でしょうか?前述したように、デコレータは継承の代替手段です。スクリプトを実行すると、サブクラスに動作を追加すると、元のクラスのすべてのインスタンスに影響しますが、デコレータには影響しません。代わりに、さまざまなオブジェクトに新しい動作を個別に追加できます。次のコードに示すように:
//装飾が必要なクラス(関数)
function Macbook() {
This.cost = function () {
1000 を返します;
};
}
関数メモリ(MacBook) {
This.cost = function () {
return macbook.cost() 75;
};
}
関数 BlurayDrive(MacBook) {
This.cost = function () {
return macbook.cost() 300;
};
}
機能 保険(MacBook) {
This.cost = function () {
return macbook.cost() 250;
};
}
// 使用法
var myMacbook = 新しい保険(新しい BlurayDrive(新しいメモリ(新しい Macbook())));
console.log(myMacbook.cost());
以下は別の例です。デコレータ オブジェクトで PerformTask を呼び出すと、いくつかのデコレータ動作が実行されるだけでなく、基になるオブジェクトの PerformTask 関数も呼び出されます。
function ConcreteClass() {
This.performTask = function () {
This.preTask();
console.log('何かをしています');
This.postTask();
};
}
関数 AbstractDecorator(装飾) {
This.performTask = function () {
decorated.performTask();
};
}
関数 ConcreteDecoratorClass(装飾) {
This.base = AbstractDecorator;
This.base(装飾);
装飾.preTask = function () {
console.log('事前呼び出し..');
};
装飾.postTask = function () {
console.log('呼び出し後..');
};
}
varconcrete = new ConcreteClass();
vardecorator1 = new ConcreteDecoratorClass(concrete);
vardecorator2 = new ConcreteDecoratorClass(decorator1);
デコレータ2.performTask();
もう 1 つの完全な例:
var ツリー = {};
Tree.decorate = function () {
console.log('木が倒れないように注意してください');
};
tree.getDecorator = function (deco) {
Tree[deco].prototype = this;
新しいツリー[デコ]を返します;
};
tree.RedBalls = function () {
This.decorate = function () {
This.RedBalls.prototype.decorate(); // ステップ 7: まず、プロトタイプのデコレート メソッドを実行します (これは Angel)
console.log('赤いボールを履いてください'); // ステップ 8 次に red を出力します
// この 2 つのステップを RedBalls のデコレートメソッドとして使用します
}
};
tree.BlueBalls = function () {
This.decorate = function () {
This.BlueBalls.prototype.decorate(); // ステップ 1: まず、プロトタイプのデコレート メソッド、つまり、tree.decorate()
を実行します。
console.log('青色のボールを追加'); // ステップ 2 次に、青色を出力します
// この 2 つのステップを BlueBalls のデコレート メソッドとして使用します
}
};
tree.Angel = function () {
This.decorate = function () {
This.Angel.prototype.decorate(); // ステップ 4: まず、プロトタイプのデコレート メソッドを実行します (これは BlueBalls)
console.log('上の天使') // ステップ 5 次に、angel
を出力します。
// この 2 つのステップを Angel のデコレートメソッドとして使用します
}
};
tree =tree.getDecorator('BlueBalls'); // ステップ 3: BlueBalls オブジェクトをツリーに割り当てます。この時点では、親プロトタイプの getDecorator はまだ利用可能です。
tree =tree.getDecorator('Angel'); // ステップ 6: Angel オブジェクトをツリーに割り当てます。この時点では、親プロトタイプの getDecorator はまだ利用可能です。
tree =tree.getDecorator('RedBalls'); // ステップ 9: RedBalls オブジェクトをtree
に割り当てます。
tree.decorate(); // ステップ 10: RedBalls オブジェクトのデコレート メソッドを実行します
デコレータ パターンは、装飾される各関数を別の関数に追加し、特別な動作が必要な場合にこの関数を使用して既存の関数オブジェクトをラップする方法です。実行するために、呼び出し元のコードは、装飾関数を選択的かつ連続的に使用して、必要に応じてオブジェクトをラップできます。利点は、クラス (関数) と装飾関数の中核となる役割が分離されていることです。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。

Quartzタイマーを使用してタスクをスケジュールする場合、Quartzでタスク通知を事前に送信する方法、タスクの実行時間はCron式によって設定されます。今...

JavaScriptプログラミング、プロトタイプチェーンの関数パラメーターの理解と操作のJavaScriptのプロトタイプチェーンの関数のパラメーターを取得する方法は、一般的で重要なタスクです...

WeChatアプレットWeb-ViewでVue.jsを使用する動的スタイルの変位障害がvue.jsを使用している理由の分析...

複数のリンクの同時ゲットリクエストを作成し、結果を返すために順番に判断する方法は? TamperMonkeyスクリプトでは、複数のチェーンを使用する必要があることがよくあります...


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

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

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

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

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

ホットトピック



