Nest安装及使用~

前提条件

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

📚要查看指南,请访问 https://docs.nestjs.com/

📚要查看中文 指南, 请访问 https://docs.nestjs.cn/

bash 复制代码
$ node -v
v16.18.1
$ npm -v
7.x.x

安装

  1. 全局安装
    npm i -g @nestjs/cli

  2. 创建目录为project-name的nest项目
    nest new project-name

启动项目

npm run start

此命令启动 HTTP 服务监听定义在 src/main.ts 文件中定义的端口号。

程序运行后, 浏览器访问 http://localhost:3000/。 可以看到Hello world!

要监听文件中的更改,您可以运行以下命令来启动应用程序:
npm run start:dev

控制器

控制器负责处理传入的请求和向客户端返回响应

Nest 为所有标准的 HTTP方法提供了相应的装饰器:@Put()、@Delete()、@Patch()、@Options()、以及 @Head()。此外,@All()则用于定义一个用于处理所有 HTTP 请求方法的处理程序

  1. 创建控制器 (也可以通过命令创建控制器nest g controller cats
    新建文件路径为src/cats/cats.controller.ts的文件
    cats.controller.ts
javascript 复制代码
import { Controller, Get, Post } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Post()
  create(): string {
    return '这是post请求';
  }

  @Get()
  // Nest会将请求路由到自定义的 findAll() 方法。请注意,此处选择的函数名称完全是任意的
  findAll(): string {
    return '这是get请求';
  }
}
  1. 引入控制器
    app.module.ts
javascript 复制代码
import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import {CatsController} from './cats/cats.controller'//引入控制器

@Module({
  imports: [],
  controllers: [AppController, CatsController],//这里用controllers包裹一下
  providers: [AppService],
})
export class AppModule {}

postman测试接口

  1. get请求
  2. post请求
相关推荐
xkxnq16 分钟前
第一阶段:Vue 基础入门(第 14天)
前端·javascript·vue.js
前端小臻16 分钟前
列举react中类组件和函数组件常用到的方法
前端·javascript·react.js
筱歌儿22 分钟前
TinyMCE-----word表格本地图片转base64并上传
前端·word
0思必得023 分钟前
[Web自动化] Selenium简单使用
前端·python·selenium·自动化·web自动化
2301_8187320625 分钟前
下载nvm后,通过nvm无法下载node,有文件夹但是为空 全局cmd,查不到node和npm 已解决
前端·npm·node.js
赵民勇26 分钟前
JavaScript中的this详解(ES5/ES6)
前端·javascript·es6
hhcccchh27 分钟前
学习vue第九天 计算属性与侦听器
前端·vue.js·学习
我的golang之路果然有问题29 分钟前
Mac 上的 Vue 安装和配置记录
前端·javascript·vue.js·笔记·macos
代码游侠33 分钟前
应用——Linux FrameBuffer图形显示与多线程消息系统项目
linux·运维·服务器·开发语言·前端·算法
小二·41 分钟前
Python Web 开发进阶实战:Flask 项目中的表单验证、错误处理与用户体验优化
前端·python·flask