ホームページ > ウェブフロントエンド > jsチュートリアル > プレゼンテーション層の Node.js アプリケーションを効率的に開発する方法について説明する記事

プレゼンテーション層の Node.js アプリケーションを効率的に開発する方法について説明する記事

青灯夜游
リリース: 2023-04-17 19:02:05
転載
1175 人が閲覧しました

フロントエンド アプリケーション開発に Node.js を使用するにはどうすればよいですか?次の記事では、プレゼンテーション層アプリケーションの開発を含む、プレゼンテーション層 Node.js アプリケーションを効率的に開発する方法を紹介します。今日私が共有したソリューションは単純なシナリオ向けであり、フロントエンド開発者がコーディング経験がなくても、Node.js に関する背景知識や専門知識を習得することなく、いくつかの単純なサーバーサイド開発タスクを完了できるようにすることを目的としています。

プレゼンテーション層の Node.js アプリケーションを効率的に開発する方法について説明する記事

私の多くの中小企業はこの状況に直面しています。大企業の開発者は自分の専門職に集中することを好み、ORM、サーバー、運用とメンテナンスなどの専門知識を習得する必要があります。 , ただし、小規模な会社では、開発タスクを直接開始して完了することができます。したがって、私の計画では、私がスタートアップで試したツールの組み合わせを紹介し、それらを簡単に共有したいと思います。

ここに示されている内容が、実際に私が今日話したいすべてです。 [関連チュートリアルの推奨事項: nodejs ビデオ チュートリアル プログラミング教育 ]

最下層は Nest.js 開発フレームワークです。実際、すべてのフレームワークが備えている最も基本的な機能のみを提供するため、どのフレームワークを使用するかは問題ではありません。 Nest.js はネットワーク層とアプリケーション層をカプセル化したもので海外での利用が多く、Spring Boot と開発方法が似ているため Java に詳しい人にとっては馴染み深いものです。

上位層では、Prisma という特殊な ORM、比較的純粋な ORM、およびモデル層の ORM を使用します。今日の私の計画全体は、Prisma を通じてすべての開発プロセスを接続し、複数のツールを相互に接続することです。基本的に、基盤となるデータ層から最上位の制御層、そして API ドキュメント全体に至るアプリケーション開発ソリューションを完成させるには、ごくわずかなコードを記述するだけで済みます。

私が最近注目しているのは、この 漸進的強化 スキームで、多くの外国人コミュニティースキームがこれに焦点を当てています。言い換えれば、今日私が話していることも含め、これらのソリューションはすべてプラグイン可能であり、他の開発作業に影響を与えることなく、それらを使用するかどうかを選択したり、一部のみを使用したりすることができます。したがって、会社がまだ比較的小規模で、この部分の仕事をフロントエンドに任せたい場合は、単にこれらのツールを使用させるだけで済みます。しかし、会社やチームが成長するにつれて、ORM、データベース、キャッシュなどを理解するプロの Node.js 開発者が必要になる場合があります。現時点では、上位レベルのツールをアンインストールしたり、Nest.js を使用したり、Nest.js を他のフレームワークに置き換えたりすることもできます。これは柔軟なアイデアであり、上位層のツールは結合度が低く、置き換え可能です。

今日紹介する 3 つのコア ツールは、Nest.js、Prisma、GraphQL です。 3つともとても重要です。

Prisma

まずは、Prisma について簡単に紹介します 公式サイトの Prisma の紹介には「次世代 Node.js」とあります。および TypeScript ORM」と述べ、型を強力にサポートしていることを強調しました。

Prisma の使用に関しては、実際には ORM ツールですが、その焦点はモデルやクラスなどを自分で定義できるようにすることではなく、使用を開始するときに最初に記述ファイルを定義することにあります。この説明ファイルと GraphQL に精通している学生は、GraphQL には 2 つの開発方法があることを知っているはずです。1 つはアーキテクチャ ファースト、もう 1 つはコード ファーストです。 Prisma は完全なソリューションとして、海外では GraphQL と密接に関連していますが、それらの間の結合は特に厳密ではなく、比較的緩和されています。

したがって、Prisma の開発では、最初に記述ファイルを定義する必要があります。このファイルには、

  • モデル (データ モデル) の定義が含まれており、これはすべての ORM が行う必要があることです。
  • DataSource (データ ソース) を定義します。これは、Prisma ではデータベースへの接続を引き継ぐためです。この層はライブラリ全体に含まれているため、接続方法に注意を払う必要はありません。データベースですが、Prisma によってデータベース接続が内部的に管理されます。
  • ジェネレーターの定義は Prisma の中心的な焦点です。データ モデルとデータ接続の管理方法を定義します。 Generator は実際に、厳密に型指定された GraphQL スキーマの JS パッケージを生成したり、型指定された DTO 定義や GraphQL スキーマ定義を生成したりできる、いくつかの公式およびサードパーティの生成ツールを定義しています。

#

したがって、Prisma を使用すると、その使用法が少し奇妙であることに気付くかもしれません。通常、他のライブラリを使用する場合は、ノード モデルで ORM のコードを直接参照するだけで済みます。ただし、Prisma のノード モデルのコードは実行時に動的に生成されるため、ダウンロード時にはまだ存在しません。ですので、Prismaを使う場合は、先ほど右のコードに書いた「this.prisma.tag」のようなモデルを実際に定義するわけではなく、通常のオブジェクトとして使うことができます。

もちろん、Prisma には他にも多くの機能がありますが、ここではその一部を列挙しました。

Prisma は、一連のデータ修正ツールを提供します。実際、多くの ORM がすでにこの機能を使用しています。しかし、一部の中小企業や小規模製品では、このツールを使用すると実際に非常に便利です。ただし、一部の大規模チームでは、このデータ修正ツールの使用が困難な場合があります。ただし、この点に関しては、この分野における Prisma の機能は実際には比較的成熟しています。

モデル内の情報を変更する必要がある場合、修正されたステートメントを生成して予測を行うのに役立ちます。たとえば、以前にフィールドを削除し、このフィールドに情報があり、必須である場合などです。これを不要に変更すると、システムは非常に複雑な修正ステートメントを生成し、予測を行ってユーザーに選択をさせます。

したがって、いくつかの小規模なシナリオでは、このデータ修正ツールは非常に便利です。最後に、修正されたレコードが生成され、この修正されたレコードを Git に同期できます。運用環境でこのツール セットを使用する必要があるかどうかについては、ここでは詳しく説明しません。

ノーコード、ノーコード、すべては先延ばし次第です。 Zaozao とチャットし、ローコードで遊んで、バス リンクに乗りましょう: www.zaozao.run/conf/c63

Nest.js

次はについてです。 Nest. js フレームワークの簡単な紹介。このフレームワークは実際には他の多くのフレームワークと非常に似ており、さまざまな開発ツールをカスケードするための階層化やグローバル フックなどのメカニズムを実装しています。 Nest.js で記述するロジックの量を最小限に抑えたいと考えています。

したがって、最終的に、完全な追加、削除、変更、クエリ操作が、複雑な操作も含めて、基本的にコードなしで Nest.js 側に実装されていることがわかります。そこで、このフレームワークがどのようなものかを簡単に説明します。

Nest.js フレームワークには、実際にはコントローラー、プロバイダー、モジュラーという 3 つの中心的な概念があります。

最も低くて最も重要なものはモジュラーです。これは、すべてのモジュールを完全なビジネス ロジックに編成するために使用される一般的な入り口です。各モジュラーには完全な層があり、入り口はコントローラーであり、すべてのリクエストは最初にコントローラー層に入ります。プロバイダーはサービス層であり、主に通常作成されるサービス層ロジックと同様のいくつかの機能を提供します。

ご覧のとおり、ここではモデル層については明示的に言及されていません。モデル層にはいくつかの定義がありますが、今日は基本的にモデル層を占める Prisma を使用します。したがって、Nest.js の開発プロセスは実際には通常の開発プロセスです。つまり、アプリケーションを作成するときに、コントローラー、サービスを作成し、DTO と VO を定義する必要があります。

Prisma を入手したら、Prisma を使用して ORM ライブラリを生成できます。また、DTO および VO コードの生成にも役立つため、コントローラーとサービスだけに集中する必要があります。さらに、Nest.js は、追加、削除、変更、クエリを実行するためのスキャフォールディングも提供します。このコマンドを実行すると、以下のようなファイル構造が生成されるので、あとはコントローラーとサービスを入力するだけです。

コントローラーを生成し、CRUD ツールであるコードを手動で記述するだけということは誰にとっても簡単なことのように思えますが、実際にはこれらは非常に基本的なものであり、役に立ちません。ロジックとコードを生成します。したがって、パラメータの型を自分で定義し、サービス層を呼び出す必要があります。もちろん、このコントローラー層のコードは比較的単純で、多くのことを行う必要はなく、ロジックはすべてサービス層にあります。ここでは、基本的なページングや条件付きフィルタリング技術、結合クエリなどの追加、削除、変更、確認のロジックを記述する必要があります。

フロントエンドがサーバーサイド開発者になることは望んでいません。サーバーサイドのフロントエンドを書くことの意義は何ですか?特に小規模なチームの場合、なぜこれを行うのでしょうか?実際、このフレームワークの本来の目的は、フロントエンドをサーバーサイド開発者に変えることではないと思いますし、そうすることはバックエンド開発者から疑問視されるかもしれません。 .js?根本的に何か変わったのでしょうか?あまり。

それでは、なぜフロントエンドがサーバーサイド開発を行う必要があるのでしょうか?実際、私の当初の目的は効率を向上させることであり、通常のインターフェイスの小さな変更に直面して、フロントエンド設計者、フロントエンド開発者、サーバー開発者が変更の完了に参加する必要を避け、それによって効率の損失を軽減しました。フロントエンドがサーバー側のコードにできるだけ触れないようにすると同時に、フロントエンドの絶え間ない変化に適応するためにインターフェイスを柔軟に調整できることを願っています。したがって、find、where、select、count などのコードをみんなに書いてほしくありません。これらの概念に慣れていないフロントエンドにとっては、問題を書きやすく、コストもかかりたくないからです。彼らがこれらのことをどのように書いているかを監視してください。

#次回も詳しくご紹介していきます。ここでは、Prisma の型が非常に強力で、モデルの型だけでなく、モデルによって生成される操作クラスの型や、さまざまなクエリ条件の型も非常に詳細に記述されていることがわかります。実際、使用されるすべての型は厳密に型指定され、モデル定義から派生します。したがって、定義には TypeScript の ORM であると記載されており、これが強みの 1 つです。

Nest.js を使用する場合は、使用するフレームワークに関係なく、認証、例外処理、統合カプセル化、リクエストの戻り値の構成など、他の作業を行う必要があります。

インターネット上にはいくつかの情報がありますが、説明が完全ではない場合もあります。必要に応じて、私の GitHub プロジェクトからクローンを作成すると、多くの落とし穴を回避できます。

通常の Nest.js と Prisma アプリケーションの開発が完了しました。実際、コードの量はそれほど多くありません。以前に Node.js のサーバーサイド開発を行った私のような人にとっては、大きすぎない圧力です。しかし、フロントエンド開発者にとって、これらのことを紹介すると、複雑なクエリ、ロジックの挿入、更新、削除をコードを書かずに実行できるか、柔軟に調整できるかなど、受け入れがたいと感じるかもしれません。フロントエンド?インターフェース?

第 63 回モーニング チャット カンファレンス - ローコード ノーコードへのご登録へようこそ。ローコード プラットフォームを通じて生産性を向上させる方法を学び、ローコードを試してみましょう。バスに乗ります:

www.zaozao.run/conf/c63

GraphQL

上記の問題を解決するには、GraphQL を導入します。これは実際には Front-エンドインターフェイスを開くメソッド。 GraphQL は万能薬ではなく、GraphQL が提供するインターフェースが高度になったり、多くの問題を解決したりするわけではありません。実際、これは特定のシナリオ、特にグラフ データ構造ではなく、元々設計されたツリー データ構造にのみ適しており、ツリー データ構造のシナリオにより適している可能性があります。

しかし、今日の私のトピックの核心は、実際には、Prisma と GraphQL の間の連携です。これは Prisma の公式定義には記載されていませんが、公式ドキュメントを見ると、Prisma と GraphQL をどのように併用できるかについてのトピックがあります。

ここでは 2 つのツールを使用しました。

prisma-nestjs-graphql

最初のツールは、Prisma のスキーマを使用して GraphQL のスキーマを生成することです。このツールは常に進化しています。以前のバージョンの prisma-nestjs-graphql を使用しています。このライブラリの名前は非常に単純です。3 つを接続し、Prisma の生成コマンドを実行してプロジェクト内のコンテンツを生成します。生成されたコンテンツには、モデルの定義 (タグなど) が含まれるだけでなく、これらの操作を定義するいくつかのパラメーターも生成されます。

私のクエリ操作は、where 条件、in、order by、group by、count、paging、その他の操作を含め、非常に柔軟です。このツールは、次のクエリに必要な操作を生成できます。これらの操作を文書化します。これらのファイルを生成してプラグインを導入すると、コードが変更されました。実際、これは追加、削除、変更、チェック機能を実装するための通常のコードです。

ここでのリゾルバーは、コントローラーのレイヤーと同様に、GraphQL 開発に実際に使用されており、実際、リゾルバー内のロジックはあまり変更されていません。これはコントローラーの定義に似ていますが、サービス層に到達すると、内部にはコードがないという魔法のようなことに気づくでしょう。通常の開発ではService層でORMを呼び出すコードを記述する必要がありますが、ここでは基本的に透過的に送信され、更新、削除、カウントなどの操作をそのまま透過的に送信することができます。もちろん、ここに通常のクエリ操作を記述することもできますが、通常の状況では、これらの操作を透過的にリゾルバーに送信するだけでよく、リゾルバーは直接透過的にフロントエンドに送信されます。

swagger-to-graphql

実際の開発プロセスでは、フロントエンド コードは、サーバーによって以前に開発されたインターフェイスにもアクセスする必要があります。これらのインターフェイスをフロントエンド コードのデータ アクセスとより適切に統合するには、Swagger の形式 (つまり、Open API の標準形式) を Graphql データに変換できる swagger-to-graphql ツールを使用する必要があります。フロントエンド コードが直接アクセスできるようにモデル化する サーバー側インターフェイス。このライブラリの使用は非常に簡単で、Swagger ドキュメントを渡し、プロバイダーを定義し、Swagger データを渡すだけで、使用する透過的な GraphQL インターフェイスが自動的に生成されます。 GraphQL ビューでは、サーバーによって定義されたインターフェイスと使用可能なすべてのクエリ パラメーターを確認できます。

第 63 回モーニング チャット カンファレンス - ローコード、ノーコード、ローコードを楽しみましょう。バスに乗ります: www.zaozao.run/conf/c63

最後に

私が共有したのは上記のすべてです。最も基本的な 3 つのこと、つまり Nest について紹介しました。 .js、Prisma、GraphQL、および私が使用するいくつかのツール。

Prisma フレームワークがどのようにして Service にコードを 1 行も書かない状態を実現するのかについて詳しく説明していませんでしたが、これは、実現が難しい GraphQL の Resolver に Prisma 自体が適応できるためです。通常の ORM ライブラリを使用します。さらに、今日共有するコンテンツは、私の GitHub リポジトリ (github.com/0xYootou/Ne…) にあります。このトピックに興味がある場合は、認証、エラー処理、戻り結果のカプセル化や、小規模なアプリケーションの開発に非常に便利な Nest.js に関するいくつかの事項を含む私のウェアハウスを見つけることができます。

ノード関連の知識の詳細については、nodejs チュートリアル を参照してください。

以上がプレゼンテーション層の Node.js アプリケーションを効率的に開発する方法について説明する記事の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート