ホームページ >ウェブフロントエンド >フロントエンドQ&A >フロントエンドとバックエンドの分離と非分離の違いは何ですか?

フロントエンドとバックエンドの分離と非分離の違いは何ですか?

青灯夜游
青灯夜游オリジナル
2020-12-15 16:25:3623004ブラウズ

違い: フロントエンドとバックエンドが分離されていない場合、フロントエンド ページに表示される効果はバックエンドによって制御され、バックエンドはページをレンダリングするかリダイレクトします。つまり、バックエンドはフロントエンドの表示と、フロントエンドとバックエンド間の結合を制御する必要があり、その度合いは非常に高いです。フロントエンドとバックエンドの分離では、バックエンドはフロントエンドが必要とするデータのみを返し、HTML ページをレンダリングせず、フロントエンドの効果を制御しなくなります。 -エンドとバックエンドは比較的低いです。

フロントエンドとバックエンドの分離と非分離の違いは何ですか?

#この記事の動作環境: Windows10 システム、Thinkpad t480 コンピューター。

関連する推奨事項: 「プログラミング ビデオ

1. フロントエンドとバックエンドの分離の概念

1. フロントエンドとバックエンドの分離

  • フロントエンドとフロントエンドの分離はアーキテクチャ パターンです。簡単に言うと、ページはバックエンド プロジェクト (JSP | HTML) では見ることができず、バックエンドはフロントエンドへのインターフェイスを提供し、フロントエンドは ## を呼び出すだけです。 #REST スタイルのインターフェイスはバックエンドによって提供され、フロントエンドはページ (html|jsp) の作成と (JS|CSS|さまざまなフロントエンド フレームワークのレンダリング) に重点を置きます。 ); バックエンドでコードを書くことに集中してください。
  • フロントエンドとバックエンドの分離の中核:
  • バックグラウンドはデータを提供し、フロントエンドは表示を担当します

1. ソフトウェア アーキテクチャ モデル

MVC 設計パターンに最もよく知られている、Model—View-Controller Model-View-Controller #########使い方 ?平たく言えば、ページに URL (リクエスト)

を入力すると、この URL はどこに行くのでしょうか?インターフェイス
  • (REST スタイル) を呼び出してください。このインターフェイスは実際にはバックエンドにアクセスするコード (メソッド) であり、バックエンドには多数のメソッドがあります。
    どのメソッドがアクセスされているかを確認するにはどうすればよいですか?インターフェイスは、たとえば、177.25.26.7/idp/user/login のように定義されます。ここで、
  • idp
  • サービス (プロジェクト)、 user を表します。はクラスを表し、login
    は呼び出される特定のメソッドを表します。Enter キーを押すと、バックエンド メソッドが直接呼び出され、バックエンド メソッドはデータベース (MySQL| Oracle|Others)# に移動します。 ## データの取得。データベース テーブル内のデータの各行はオブジェクト、つまり JavaBean を表し、最終的に pojo メソッドを使用してコレクション フレームワーク に保存されます ( List|Map|Set|etc.) 、メソッドはこのセットを返し、このインターフェイスを呼び出した結果は (応答) で結果セットが得られ、フロントエンドがデータを取得します。その後、ページ (html|Jsp) を通じて表示されます。ユーザーに表示されるのは、View レイヤーの機能です。 2. フロントエンドとバックエンドを分離する理由

以前、という話を聞きました。 TDD (テスト駆動開発、テスト駆動開発) はコードの品質を向上させることができるため、TDD

を実装しました。その後、

BDD (動作駆動開発、動作-駆動開発)でビジネスニーズに合わせた製品を提供できる ソフトウェアについてはBDDを導入しましたが、その後DDD(ドメイン駆動設計、ドメイン駆動設計)でビジネスコードと基本コードを分離できると聞きましたということで、DDDを実装しました。今日、フロントエンドとバックエンドの分離が非常に人気があると聞いたので、フロントエンドとバックエンドの分離を実装しました。これが伝説的な HDD (Hype-driven Development) です。 プロセス: TDD -》 BDD -》 DDD =》 HDD

3. フロントエンドとバックエンドの分離

フロントエンドとバックエンドを分離すると、フロントエンドとフロントエンドの間の分業が不均等であるという問題を十分に解決できます。処理のためにフロントエンドに割り当てられ、バックエンドは独自の作業に集中できます。たとえば、権限制御と計算作業のための API インターフェイスが提供されます。フロントエンド開発者は、nodejs

を使用して独自のローカル サーバーを構築し、ローカルで直接開発し、いくつかのプラグインを通じて

api リクエストをバックグラウンドに転送することで、完全にシミュレーションできるようになります。ラインやシーンを背景から分離します。フロントエンドはユーザーとの対話プロセス全体を独立して完了でき、両方が相互に依存することなく同時に作業を開始できるため、開発効率が向上し、分業のバランスが比較的取れます。 #利点は次のように要約されます。

開発効率の向上複雑で変化する最前線に完全に対応します。 -エンドの要件

コードの保守性の強化
  • #2. フロントエンドとバックエンドの分離とフロントエンドとバックエンドの非分離の違い分離

#1. フロントエンドとバックエンドは分離されていません##

  • フロントエンドとバックエンドが分離されていないアプリケーション モードでは、フロントエンド ページに見られる効果は、ページをレンダリングしたりリダイレクトしたりするバックエンドによって制御されます。エンドはフロントエンドの表示を制御する必要があり、フロントエンドとバックエンドは高度に結合されています。
  • このアプリケーション モードは純粋な Web アプリケーションにより適していますが、バックエンドが App に接続されている場合、App はバックエンドが を返す必要がない場合があります。 HTMLWeb ページですが、データ自体だけなので、Web ページを返すバックエンドの元のインターフェイスは、フロントエンド App アプリケーションには適用できなくなります。 #App バックエンドでは、別のインターフェイスのセットを開発する必要があります。

2. フロントエンドとバックエンドの分離

    #フロントエンド分離の応用モードの場合-エンドとフロントエンドの場合、バックエンドはフロントエンドのデータのみを返します。必要なデータはレンダリングされなくなり、
  • HTML ページはレンダリングされなくなり、フロントエンドの効果は次のようになります。もう制御されなくなりました。フロントエンド ユーザーにどのような影響が及ぶか、またバックエンドから要求されたデータがどのようにフロントエンドに読み込まれるかについては、フロントエンド自体に依存します。Web ページには独自の処理方法があり、App には独自の処理方法がありますが、どのフロントエンドを使用しても、必要なデータは基本的に同じであり、バックエンドは外部にデータを提供するためのロジックを開発するだけで済みます。 フロントエンドとバックエンドが分離されているアプリケーションモデルでは、フロントエンドとバックエンド間の結合度は比較的低くなります。
  • フロントエンドとバックエンドが分離されているアプリケーション モデルでは、通常、バックエンドによって開発された各ビューをインターフェイス、つまり
  • API
  • と呼びます。フロントエンドはデータの追加、削除、変更を行います。アクセスインターフェイス経由でチェックしてください。
  • さらに関連記事を読みたい場合は、
  • PHP 中国語 Web サイト
にアクセスしてください。 !

以上がフロントエンドとバックエンドの分離と非分離の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。