gpt4 book ai didi

NestJS的基础知识和核心基础

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章NestJS的基础知识和核心基础由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

  。

介绍 。

NestJS是个相对较新的框架,使用NodeJS开发后端应用程序变得容易。并且,NestJS正在逐渐被越来越多的用户使用.

在这篇文章中,我们将了解构成这个框架主干的NestJS 基础知识和核心基础知识。为了更好地理解 NestJS 基础知识,将使用 Nest CLI 引导一个入门应用程序.

1. 语言 。

用于编写 NestJS 应用程序的核心语言是Typescript。然而,由于 NestJS 是建立在 NodeJS 之上的,它也支持普通的 JavaScript。NestJS使用最新的语言特性,因此需要类似Babel这样的编译器来进行编译.

由于 NestJS 具有灵活性,可以根据开发团队的需要和专业知识使用Typescript或Javascript。然而,NestJS 的创建者似乎更倾向于使用 Typescript.

2. 设置 NestJS 。

NestJS 需要 NodeJS 和 NPM 作为先决条件。因此,在进行下一步操作之前,请确保两者都存在于您的系统中.

根据官方文档,NestJS 需要 10.13 以上的 NodeJS 版本.

一旦安装了 NodeJS,启动一个新的 NestJS 项目就非常简单了。我们首先需要使用以下命令安装 NestJS CLI.

$ npm i -g @nestjs/cli

在这里,我们将在全球范围内安装 NestJS CLI。如果您遇到一些与权限相关的问题,请参阅本文.

接下来,我们可以使用 Nest CLI 创建一个新项目.

$ nest new demo-project

此命令将创建一个名为 demo-project 的目录,并且将安装node_modules(以及一些其他样板文件)。我们将有一个/src目录,其中包含几个核心文件.

drwxr-xr-x   7 saurabhdashora  staff  224 Jul 24 09:46 .drwxr-xr-x  16 saurabhdashora  staff  512 Jul 24 09:50 ..-rw-r--r--   1 saurabhdashora  staff  617 Jul 24 09:46 app.controller.spec.ts-rw-r--r--   1 saurabhdashora  staff  274 Jul 24 09:46 app.controller.ts-rw-r--r--   1 saurabhdashora  staff  249 Jul 24 09:46 app.module.ts-rw-r--r--   1 saurabhdashora  staff  142 Jul 24 09:46 app.service.ts-rw-r--r--   1 saurabhdashora  staff  208 Jul 24 09:46 main.ts

3. NestJS 核心文件 。

以下是核心文件的简要概述:

app.controller.ts 这是一个带有单一路由的最小控制器
app.controller.spec.ts 此文件包含控制器的单元测试
app.module.ts 应用程序的根模块
应用服务.ts 具有单一方法的基本服务
主文件 使用核心 NestFactory 函数的应用程序的入口文件。基本上,这负责启动应用程序实例。

让我们更详细地了解main.ts :

 
  1. main.tsimport { NestFactory } from '@nestjs/core'
  2. import { AppModule } from './app.module'
  3.  
  4. async function bootstrap() { 
  5.   const app = await NestFactory.create(AppModule); 
  6.   await app.listen(3000); 
  7. bootstrap(); 

在第 1 行中,我们从 NestJS 核心包中导入NestFactory函数.

NestFactory 公开了一些静态方法,我们可以使用create() 方法,创建一个应用程序实例。为此,我们导入 AppModule 并将其传递给create()调用。请参阅第 5 行.

基本上,application对象提供了一组方法,我们可以使用这些方法在端口 3000 上启动我们的 HTTP 侦听器。最后,我们调用第8行中的 bootstrap() 函数.

4. 运行 NestJS 应用 。

使用 Nest CLI 搭建的项目启动应用程序所需的一切。我只需执行以下命令简单地启动服务器:

$ npm run start

我们应该看到如下输出:

> demo-project@0.0.1 start /Users/saurabhdashora/NestProjects/demo-project> nest start[Nest] 3640  - 07/24/2021, 10:57:51 AM     LOG [NestFactory] Starting Nest application...[Nest] 3640  - 07/24/2021, 10:57:51 AM     LOG [InstanceLoader] AppModule dependencies initialized +26ms[Nest] 3640  - 07/24/2021, 10:57:51 AM     LOG [RoutesResolver] AppController {/}: +6ms[Nest] 3640  - 07/24/2021, 10:57:51 AM     LOG [RouterExplorer] Mapped {/, GET} route +1ms[Nest] 3640  - 07/24/2021, 10:57:51 AM     LOG [NestApplication] Nest application successfully started +1ms

基本上,该命令会启动 HTTP 服务器,监听 main.ts 文件中定义的端口。在我们的例子中,端口是 3000.

应用程序运行后,我们可以访问浏览器并点击http://localhost:3000。我们将看到Hello World!打印出来 .

5. NestJS 平台独立性 。

NestJS 的目标是与平台无关。这使得 NestJS 开发人员可以编写可重用的逻辑。换句话说,在不同类型的应用程序中使用相同的逻辑变得十分容易.

从技术上讲,一旦创建了适配器,NestJS 就可以与任何 Node HTTP 框架一起使用。但是,开箱即用,它同时支持express和fastify。开发人员可以选择适合他们需求的任意一种.

平台express或express是默认选择。另一个选项是platform-fastify。Fastify是一个专注于效率的高性能框架.

这两个平台都有自己的接口。它们分别被视为NestExpressApplication和NestFastifyApplication.

我们可以在 app.create() 调用中配置它们,如下所示:

 
  1. const app = await NestFactory.create < NestExpressApplication > (AppModule); 

上述方法将NestExpressApplication的特定方法公开为应用程序对象的一部分。但是,如果我们不想访问特定的方法,则不需要指定类型.

结论 。

通过本文,我们已经可以了解 NestJS 基础知识和核心基础知识。并且安装 Nest CLI,然后启动了第一个项目。此外,我们探索了starter文件及其用途,并特别关注了负责启动应用程序的main.ts文件.

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】 。

原文地址:https://developer.51cto.com/art/202108/678431.htm 。

  。

最后此篇关于NestJS的基础知识和核心基础的文章就讲到这里了,如果你想了解更多关于NestJS的基础知识和核心基础的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com