Nest(二):第一步

译自:https://docs.nestjs.com/first-steps

在本系列文章中,您将学习Nest的核心基础知识。为了熟悉Nest应用程序的基本构建块,我们将构建一个基本的CRUD应用程序,它的特性涵盖了入门级的很多内容。

语言

我们热爱TypeScript,但最重要的是,我们热爱Node.js。这就是为什么Nest兼容TypeScript和纯JavaScript。Nest利用了最新的语言特性,因此要将其与普通JavaScript一起使用,我们需要一个Babel编译器。

在我们提供的示例中,我们将主要使用TypeScript,但是您总是可以将代码片段切换为普通的JavaScript语法(只需单击每个代码片段的右上角的language按钮)。

要求

请确保您的操作系统上安装了Node.js(>= 8.9.0)。

设置

使用Nest CLI设置新项目非常简单。安装了npm后,您可以在OS终端中使用以下命令创建一个新的Nest项目:

$ npm i -g @nestjs/cli
$ nest new project-name

将创建project目录,安装节点模块和其他一些样板文件,并创建一个src/目录,并用几个核心文件填充。

image.png

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

文件 说明
app.controller.ts 有一个单一路由的基本控制器样本。
app.module.ts 应用程序的根模块。
main.ts 应用程序的入口文件,它使用核心函数NestFactory创建一个Nest应用程序实例。

main.ts包含一个异步函数,它将启动我们的应用程序:

import { NestFactory } from '@nestjs/core';
import { ApplicationModule } from './app.module';

async function bootstrap() {
  const app = await NestFactory.create(ApplicationModule);
  await app.listen(3000);
}
bootstrap();

要创建一个Nest应用程序实例,我们使用核心NestFactory类。NestFactory公开了一些静态方法,这些方法允许创建应用程序实例。create()方法返回一个应用程序对象,该对象填充INestApplication接口。这个对象提供了一组方法,这些方法将在下一章中描述。在上面的main.ts示例中,我们简单地启动HTTP侦听器,让应用程序等待入站HTTP请求。

请注意,使用Nest CLI构建的项目创建了一个初始项目结构,该结构鼓励开发人员遵循将每个模块保存在其专用目录中的约定。

平台

Nest的目标是成为一个平台无关的框架。平台独立性使得创建可重用逻辑部件成为可能,开发人员可以跨几种不同类型的应用程序利用这些逻辑部件。从技术上讲,一旦创建了适配器,Nest就可以使用任何节点HTTP框架。有两种HTTP平台支持开箱即用:expressfastify。你可以选择最适合你需要的。

平台 描述
platform-express Express是一个著名的用于node的极简web框架。这是一个经过测试的、可生产的库,社区提供了大量的资源。默认情况下使用@nestjs/platform-express包。许多用户都很好地使用了Express,不需要采取任何行动来启用它。
platform-fastify Fastify是一个高性能、低开销的框架,高度专注于提供最大的效率和速度。在这里阅读如何使用它。

无论使用哪种平台,它都公开自己的应用程序接口。它们分别被看作NestExpressApplicationNestFastifyApplication

当您将一个类型传递给NestFactory.create()方法(如下面的示例所示)时,app对象将拥有专门针对该特定平台的方法。但是,请注意,除非您确实想访问底层平台API,否则不需要指定类型。

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

运行应用程序

安装过程完成后,可以在OS命令提示符下运行以下命令,启动应用程序侦听HTTP请求:

$ npm run start

该命令启动应用程序,HTTP服务器监听src/main.ts中定义的端口文件。应用程序运行后,打开浏览器并导航到http://localhost:3000/。你应该看看Hello world!消息。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容

  • TypeScript 是微软开发和控制的开源项目,我在应用 Anguar 2+ 和 Ionic 2+ 框架开发系统...
    廖全磊LesterLiao阅读 1,632评论 0 3
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,097评论 1 32
  • 这是去年班里发生的一件让我感到非常羞愧的事情,容我深呼吸,慢慢道来。 M老师给我们布置作业...
    星空沫䁔阅读 246评论 0 1
  • 最近只要有时间基本都在看公众号,干货很多,水货也很多,对于阅读速度不快的我来说,有些小小的压力。 不过我找到了鼓励...
    PsyOxygen阅读 475评论 0 0
  • 前天晚上睡觉的时候想起奶奶了,现在也想不起来到底因为什么原因了,不过这也不重要了。之前也有很多次想起过,这次决定稍...
    在乎丶你的在乎阅读 595评论 0 1