TypeScript のデザイン パターンの理解と実装
デザイン パターンは、ソフトウェア開発で繰り返し発生する問題に対する汎用的な解決策です。これらのパターンは、コードを体系的に構造化するのに役立ち、システムのメンテナンス、再利用、拡張性を容易にします。 JavaScript のスーパーセットである TypeScript では、強力な型指定とオブジェクト指向機能により、デザイン パターンをさらに効率的に実装できます。
この投稿では、デザイン パターンの 3 つの主要なカテゴリ (創造、構造、動作) と、それらを TypeScript で実装する方法について説明します。
1. 創作パターン
作成パターンはオブジェクトの作成を処理し、インスタンス プロセスをカプセル化し、コードの再利用を促進します。
例: シングルトン
シングルトンは、アプリケーションのライフサイクル全体を通じて、クラスが単一のインスタンスのみを持つことを保証します。
class Singleton { private static instance: Singleton; private constructor() {} static getInstance(): Singleton { if (!Singleton.instance) { Singleton.instance = new Singleton(); } return Singleton.instance; } someMethod() { console.log("Método do Singleton"); } } const instance1 = Singleton.getInstance(); const instance2 = Singleton.getInstance(); console.log(instance1 === instance2); // true
上記の例では、getInstance() メソッドにより、Singleton クラスのインスタンスが 1 つだけ作成されることが保証されています。
2. 構造パターン
構造パターンはクラスとオブジェクトの構成を扱い、より小さく単純な部分から大規模なコード構造を構築できるようにします。
例: アダプター
アダプター パターンを使用すると、互換性のない 2 つのインターフェイスを連携させることができます。これは、コードが期待するものとは異なるインターフェイスを持つクラスを使用する場合に便利です。
// Interface antiga class OldAPI { oldRequest() { return "Dados da API antiga"; } } // Interface nova class NewAPI { newRequest() { return "Dados da API nova"; } } // Adapter que adapta a interface antiga para a nova class APIAdapter { private oldAPI: OldAPI; constructor(oldAPI: OldAPI) { this.oldAPI = oldAPI; } newRequest() { return this.oldAPI.oldRequest(); } } const oldAPI = new OldAPI(); const adapter = new APIAdapter(oldAPI); console.log(adapter.newRequest()); // "Dados da API antiga"
この例では、アダプター (APIAdapter) により、NewAPI が期待するインターフェースで OldAPI クラスを使用できるようになります。
3. 行動パターン
動作パターンはオブジェクト間の相互作用と通信を扱い、コードの柔軟性と分離を促進します。
例: オブザーバー
Observer パターンは、オブジェクト間の 1 対多の依存関係を定義するため、オブジェクトの状態が変化すると、そのすべての依存関係が自動的に通知され、更新されます。
interface Observer { update(data: any): void; } class Subject { private observers: Observer[] = []; addObserver(observer: Observer) { this.observers.push(observer); } removeObserver(observer: Observer) { this.observers = this.observers.filter(obs => obs !== observer); } notifyObservers(data: any) { this.observers.forEach(observer => observer.update(data)); } } class ConcreteObserver implements Observer { update(data: any) { console.log("Observer atualizado com dados:", data); } } const subject = new Subject(); const observer1 = new ConcreteObserver(); const observer2 = new ConcreteObserver(); subject.addObserver(observer1); subject.addObserver(observer2); subject.notifyObservers("Alguma informação importante"); // Ambos observers recebem a atualização
上記の例では、Observer パターンにより、複数のオブジェクトが対象オブジェクト (Subject) の状態の変化を観察し、それに反応することができます。
結論
デザイン パターンは、堅牢でスケーラブルなコードを構築するための強力なツールです。 TypeScript は、静的型付けとオブジェクト指向の特性を備えており、これらの標準を実装するための優れた環境であり、開発のセキュリティと生産性が向上します。
作成パターン、構造パターン、および動作パターンを使用することで、コードの可読性と保守性を向上させるプラクティスを採用し、一般的な開発上の問題に対する効果的な解決策を確保します。
この投稿が、TypeScript でデザイン パターンを適用する方法を理解するのに役立つことを願っています。これらの実装をプロジェクトで試して、コードの品質がどのように向上するかを確認してください!
以上がTypeScript のデザイン パターンの理解と実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











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

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

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

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

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

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

Zustand非同期操作のデータの更新問題。 Zustand State Management Libraryを使用する場合、非同期操作を不当にするデータ更新の問題に遭遇することがよくあります。 �...
