Laravel のサービスプロバイダーとファサードパターンの簡単な紹介
この記事では、Laravel でのサービス プロバイダーとファサード パターンの使用に関する関連情報を主に紹介します。詳細なサンプル コードを通じて、学習や学習に役立ちます。この作品には一定の参考と学習価値があり、それを必要とする友人が一緒に学ぶことができます。
まえがき
laravelでは、追加したクラスを使用する必要がある場合、クラスファイルを保存するための専用フォルダーを作成できます。 Laravel のサービスプロバイダーを使用することもできます。
実際には、この 2 つに大きな違いはありません。前者を使用する場合、コントローラーが多くのカスタム クラス ファイルを参照する場合、それがビジネス コードに依存するためです。どれだけの依存関係が生成されるのかを想像してください。この場合、サービスプロバイダーのメソッドを使用して、laravel コンテナーにクラスを登録できます。これにより、依存関係を別の構成ファイルで管理できるようになり、ロジックとその後のメンテナンスが大幅に楽になります。便利。
ファサードを使用する主な理由は、クラスをインスタンス化する必要がないため、静的メソッドを使用してクラス メソッドにアクセスできるためです。ただし、これには実際にはアクセスできないなどの欠点があります。対応するメソッド内に直接ジャンプします。このメソッドの使用方法を直感的に理解することはできません。個人で開発する場合はあまり影響がないかもしれませんが、チームで開発する場合は少しめまいがするかもしれません。
Laravel に付属のファイル システムを例にとると、サービス プロバイダーは config/app.php の構成ファイルのプロバイダー配列に登録されます:
Illuminate\Filesystem\FilesystemServiceProvider::class,
ファサードはエイリアス配列で定義されます:
‘File' => Illuminate\Support\Facades\File::class,
これらの 2 つの手順により、Laravel を非常に便利に使用できるようになります ファイル システム関連の操作呼び出し形式は非常に単純です。
File::exist($path)
ファイルが存在するかどうかを確認します。File::get($path, $lock = false)
、ファイルの内容を取得します。File::append($path, $data)
、コンテンツをファイルの末尾に追加します。File::files($directory)
、ディレクトリ内のすべてのファイルを取得します。
それでは、これはどのように行われるのでしょうか? Laravelのサービスプロバイダーとファサードモードについてそれぞれ話しましょう。
サービスプロバイダー
最初に定義を見てみましょう:
サービスプロバイダーは、すべての Laravel が集中する中心です。アプリケーションが開始されます。独自のアプリケーションを含むすべてのコア Laravel サービスは、サービスプロバイダーを通じて開始されます。
/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php にあるファイル システム サービス プロバイダーでは、 register メソッドでシングルトンがバインドされていることを確認できます。
protected function registerNativeFilesystem() { $this->app->singleton('files', function () { return new Filesystem; }); }
このシングルトンは、Filesystem クラスのシングルトン モードです。もちろん、このサービス プロバイダーは他のシングルトンをバインドしたり、さらに多くのことを実行したりすることもできます。ここでは File::exist()
の原理のみを学習します。
つまり、ファイルのインスタンスは 1 つですが、これは実際には Filesystem クラスのインスタンスです。
現時点で、Facade がない場合は、ファイルシステム インスタンスのメソッドを呼び出すこともできます。つまり、次のように呼び出すことができます:
app(‘files')->exist($path)
さて、ファサードについて話しましょう。
ファサード ファサード モード
最初に概要を見てみましょう:
Facades /fəˈsäd/ はアプリケーションです。アプリケーションのサービス コンテナで利用可能なクラスは、「静的」インターフェイスを提供します。 Laravel には、ほぼすべてのサービスにアクセスするために使用できる多くのファサードが付属しています。 Laravel ファサードは、サービス コンテナ内の基本クラスの「静的プロキシ」です。従来の静的メソッド呼び出しと比較して、ファサードはよりシンプルで豊富な構文を提供すると同時に、より優れたテスト容易性とスケーラビリティを備えています。
この記事の冒頭で、エイリアス配列がファイルを定義すると述べました。特定のクラスは
Illuminate\Support\Facades\File::class,
その内容は次のとおりです。
class File extends Facade { /** * Get the registered name of the component. * * @return string */ protected static function getFacadeAccessor() { return 'files'; } }
Laravel フレームワークの PHP オブザーバー パターン
以上がLaravel のサービスプロバイダーとファサードパターンの簡単な紹介の詳細内容です。詳細については、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)

ホットトピック









Laravel 9 と CodeIgniter 4 の最新バージョンでは、更新された機能と改善が提供されます。 Laravel9はMVCアーキテクチャを採用しており、データベース移行、認証、テンプレートエンジンなどの機能を提供します。 CodeIgniter4 は、HMVC アーキテクチャを使用してルーティング、ORM、およびキャッシュを提供します。パフォーマンスの面では、Laravel9 のサービスプロバイダーベースの設計パターンと CodeIgniter4 の軽量フレームワークにより、優れたパフォーマンスが得られます。実際のアプリケーションでは、Laravel9 は柔軟性と強力な機能を必要とする複雑なプロジェクトに適しており、CodeIgniter4 は迅速な開発や小規模なアプリケーションに適しています。

Laravel と CodeIgniter のデータ処理機能を比較します。 ORM: Laravel はクラスとオブジェクトのリレーショナル マッピングを提供する EloquentORM を使用しますが、CodeIgniter は ActiveRecord を使用してデータベース モデルを PHP クラスのサブクラスとして表します。クエリビルダー: Laravel には柔軟なチェーンクエリ API がありますが、CodeIgniter のクエリビルダーはよりシンプルで配列ベースです。データ検証: Laravel はカスタム検証ルールをサポートする Validator クラスを提供しますが、CodeIgniter には組み込みの検証関数が少なく、カスタム ルールの手動コーディングが必要です。実践例:ユーザー登録例はLarを示しています

初心者にとって、CodeIgniter は学習曲線が緩やかで機能は少ないですが、基本的なニーズはカバーしています。 Laravel は幅広い機能セットを提供しますが、学習曲線はわずかに急になります。パフォーマンスの点では、Laravel と CodeIgniter はどちらも良好なパフォーマンスを示します。 Laravel にはより広範なドキュメントとアクティブなコミュニティ サポートがあり、CodeIgniter はよりシンプルで軽量で、強力なセキュリティ機能を備えています。ブログアプリケーションを構築する実際のケースでは、Laravel の EloquentORM を使用するとデータ操作が簡素化されますが、CodeIgniter ではより手動の構成が必要になります。

Laravel - アーティザン コマンド - Laravel 5.7 には、新しいコマンドを処理およびテストするための新しい方法が付属しています。これには職人コマンドをテストする新しい機能が含まれており、そのデモについては以下で説明します。

大規模プロジェクト用のフレームワークを選択する場合、Laravel と CodeIgniter にはそれぞれ独自の利点があります。 Laravel はエンタープライズレベルのアプリケーション向けに設計されており、モジュール設計、依存関係の注入、強力な機能セットを提供します。 CodeIgniter は、速度と使いやすさを重視した、小規模から中規模のプロジェクトに適した軽量フレームワークです。複雑な要件と多数のユーザーを伴う大規模なプロジェクトには、Laravel のパワーとスケーラビリティがより適しています。単純なプロジェクトやリソースが限られている状況では、CodeIgniter の軽量で迅速な開発機能がより理想的です。

小規模なプロジェクトの場合、Laravel は強力な機能とセキュリティを必要とする大規模なプロジェクトに適しています。 CodeIgniter は、軽量さと使いやすさを必要とする非常に小規模なプロジェクトに適しています。

Laravel の Blade と CodeIgniter の Twig テンプレート エンジンを比較し、プロジェクトのニーズと個人的な好みに基づいて選択してください。Blade は MVC 構文に基づいており、適切なコード編成とテンプレートの継承を促進します。 Twig は、柔軟な構文、強力なフィルター、拡張サポート、セキュリティ サンドボックスを提供するサードパーティ ライブラリです。

Laravel - Artisan Console - Laravel フレームワークは、コマンドラインを介した対話のための 3 つの主要なツール、つまり Artisan、Ticker、REPL を提供します。この章ではArtisanについて詳しく説明します。
