最近、Yii Framework の MVC フレームワークを使用したプロジェクトを担当したのですが、最初は非常に堅牢な構造だと思いました。
しかし、ビジネス ロジックについての理解を深めていくにつれて、問題の深刻さに気づき始めました。
私は MVC の Controller を誤解しており、過去の経験に基づいて、すべてのビジネス ロジックが Controller の action# に配置されることが当然だと思っていました。 ## 実装する。
Controller には数千行の コードが含まれ、ますます肥大化してきています。 ついに、私はコードを再構築することを決意しましたが、その原点は、オープン API インターフェイスの必要性でした。
現在のアーキテクチャでは、コードの再利用は基本的に不可能なので、多くの関数を何度も何度も記述する必要があり、これはとても容認できません。 オブジェクト指向プログラミングは教科書に載っているだけの用語ではありません。 実践を始めて初めて、オブジェクト指向の意識とグローバルな視点を持つことがいかに珍しいかに気づきました。1 MVC とは正確には何ですか
Model-View-Controller (MVC) は、
の一種です。設計フレームワーク (設計パターン)。 MVC の
目標は、ビジネス ロジックをユーザー インターフェイスの考慮事項から分離することです。 これにより、開発者は他の部分に影響を与えることなく、各部分をより簡単に変更できます。
MVC では、モデルは
- データとビジネス ルールを表します
- ; ビューには ## が含まれます#ユーザー インターフェイス要素 (テキスト、フォーム
- など); コントローラーは、モデルとビュー間の 通信
- を管理します。 MVC はさまざまなプログラミング言語で実装されています。たとえば、J2EE アプリケーション開発では、 View は jsp によって実装される場合があります。コントローラーはサーブレットであり、現在は一般的に Struts で実装されます。モデルエンティティBeanによって実装されます。
Yii Framework は、Ruby on Rails を利用する人気の PHP フレームワークですActiveRecord(
AR# ##) コンセプト。データベース内のすべての
table は、
AR
AR をモデルとして扱い、
models という名前のディレクトリに配置することをお勧めします。
実際には、
私たちの業務のほとんどすべてがコントローラーに置かれています。 ユーザーが送信したフォームに対してさまざまな論理的判断を行い、計算を実行し、AR をインスタンス化し、データを保存します...
Controller内に複数のactionが存在するため、それぞれのaction
にこのような業務処理が存在します。ついに、コントローラーのコードが 1000 行を超えていることがわかりました。
ある日突然、リーダーは、私たちのシステムがサードパーティのインターフェイスを呼び出して提供できるように、既存の古いシステム用の API をオープンする必要があると言いました。
その責任は、ユーザー入力を受け入れ、それをすぐに他のクラスに転送して処理することだけです。
。このように、コントローラーは異なるインターフェイスを提供することだけを担当するため、ビジネス ロジックを分離することができ、分離されたビジネスを簡単に再利用できます。 ビジネスのこの分離された部分は誰が処理するのでしょうか?答えは Model
となるはずです。3 View
View の責任は比較的明確で、表示を担当します。
表示インターフェイスと関係のないものはすべてビューに表示されるべきではありません。
したがって、通常は View に複雑な判断文や複雑な計算処理を含めるべきではありません。
単純なループ ステートメントと書式設定ステートメントを使用できます。たとえば、ブログのトップページにあるテキストリストは一種のループです。 PHP Web アプリケーションの場合、HTML が View
のメイン コンテンツです。
View はモデル記述メソッド を決して呼び出さないでください。
つまり、View は Model からデータを読み取るだけで、Model を書き換えることはありません。
したがって、ビューとモデルは切り離せないものであると言えます。
さらに、$_GET
と $_POST
は View から直接アクセスされず、Controller によって View に渡される必要があります。
さらに、View には通常、データベースへのクエリなどのデータ処理を準備するためのコンテンツが含まれていません。 これらは通常、コントローラーに配置され、変数の形式でビューに渡されます。
つまり、
ビューで使用されるデータは変数 です。
4 モデルの責任モデル
にとって最も重要なことは、情報の保存と出力です。 たとえば、Post クラスには、ブログ投稿のタイトルを保存するために使用される title 属性が必要であり、削除操作も必要です。これらはすべてモデルの内容です。
データ、動作、およびメソッドは、Model
の主な内容です。 実際の作業では、MVC のコード量が最も多いのは
Model です。 モデルは、アプリケーションのビジネス ロジックもここで表現する必要があるため、ロジックの最も複雑な部分です。 モデルとコントローラーの区別に注意してください。
Model はビジネス ロジックを処理し、Controller は単に Model と View の間の関係を調整します。
ビジネスに関連するものであれば、モデルに含める必要があります。
#データ検証、パブリック定数と変数はすべてモデル層に配置する必要があります。言い換えると、再利用できる属性やメソッドはモデル層に配置し、一度定義すればどこでも使用できるということです。 モデルはリクエスト、セッション、その他の環境データにアクセスしてはなりません。これらはコントローラーによって挿入される必要があります。
優れたデザインとは、 太いモデルと薄いコントローラー である必要があります。5 コントローラーの責任
コントローラーの場合、主にユーザーのリクエストに応答し、使用するビューを決定します。準備が必要なデータ
を表示するために使用されるデータ。したがって、request のアクセス コードは、$_GET
などのコントローラー に配置する必要があります。 # #$_POST など。 コントローラーはユーザー リクエスト データの取得に限定する必要があります。データに対して操作や前処理を実行することはできません。これはモデル内に配置する必要があります。
データ書き込み操作の場合、完了するには Model クラスのメソッドを呼び出す必要があります。
ユーザーのリクエストに応じて、ビューのレンダリングが呼び出されます。
さらに、通常、HTML コードやその他のプレゼンテーション層のものは存在すべきではありません。、これがビューのコンテンツである必要があります。
6 啓発Yii Framework の公式ドキュメントには次の段落があります:適切に設計された MVC アプリケーションでは、コントローラー多くの場合、モデルは非常に薄く、おそらく数十行のコードしか含まれていませんが、モデルは非常に太く、データの表現と操作を担当するコードの大部分が含まれています。モデルの方が優れています。
以上がMVC アーキテクチャの意味と責任分担を説明する例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。

PHPでは、特性は方法が必要な状況に適していますが、継承には適していません。 1)特性により、クラスの多重化方法が複数の継承の複雑さを回避できます。 2)特性を使用する場合、メソッドの競合に注意を払う必要があります。メソッドの競合は、代替およびキーワードとして解決できます。 3)パフォーマンスを最適化し、コードメンテナビリティを改善するために、特性の過剰使用を避け、その単一の責任を維持する必要があります。

依存関係噴射コンテナ(DIC)は、PHPプロジェクトで使用するオブジェクト依存関係を管理および提供するツールです。 DICの主な利点には、次のものが含まれます。1。デカップリング、コンポーネントの独立したもの、およびコードの保守とテストが簡単です。 2。柔軟性、依存関係を交換または変更しやすい。 3.テスト可能性、単体テストのために模擬オブジェクトを注入するのに便利です。

SplfixedArrayは、PHPの固定サイズの配列であり、高性能と低いメモリの使用が必要なシナリオに適しています。 1)動的調整によって引き起こされるオーバーヘッドを回避するために、作成時にサイズを指定する必要があります。 2)C言語アレイに基づいて、メモリと高速アクセス速度を直接動作させます。 3)大規模なデータ処理とメモリに敏感な環境に適していますが、サイズが固定されているため、注意して使用する必要があります。

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

JavaScriptでは、nullcoalescingoperator(??)およびnullcoalescingsignmentoperator(?? =)を使用できます。 1.??最初の非潜水金または非未定されたオペランドを返します。 2.??これらの演算子は、コードロジックを簡素化し、読みやすさとパフォーマンスを向上させます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

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