Nest:路由、控制器、服务(三)

路由 (Routing)

在 Nest.js 中,路由定义了客户端请求与服务器响应之间的映射关系。

每个路由关联一个 URI 和一个 HTTP 请求方法(如 GET、POST 等)。

控制器(Controllers)

控制器是管理路由请求的组件,通过类实现,并与模块(Modules)相关联。

在 Nest.js 中,用装饰器(Decorators)来定义控制器和路由规则:

  • @Controller() 装饰器定义一个基本的控制器。可传递一个路径前缀,这样所有的路由都会基于这个前缀。
  • @Get(), @Post(), @Put(), @Delete() 等装饰器用于定义具体的请求方法和路径。
typescript 复制代码
import { Controller, Get } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Get()
  findAll(): string {
    return 'This action returns all cats';
  }
}

在此例中,CatsController 控制器定义了一个 GET 请求的路由 /cats,当请求到达时,将调用 findAll 方法并返回所有猫咪的信息。

服务(Service)

服务是 Nest.js 的核心概念之一,用于封装业务逻辑,如数据库交互、外部接口调用等。服务通过 @Injectable() 装饰器标注的类实现。

创建服务

服务可以通过 CLI 命令 nest generate service [name] 创建,或手动添加 @Injectable() 装饰器。例如:

typescript 复制代码
import { Injectable } from '@nestjs/common';

@Injectable()
export class YourService {
  // 业务逻辑方法
  test() {
    // 执行一些逻辑操作,返回处理后的结果
    return result;
  }
}

注入服务

服务可以注入到控制器或其他服务中,Nest.js 的依赖注入系统会自动实例化服务。例如:

typescript 复制代码
import { Controller } from '@nestjs/common';
import { YourService } from './your.service';

@Controller('your-route')
export class YourController {
  // 注入服务
  constructor(private yourService: YourService) {}

  // 使用 yourService 的方法
  @Get()
  find() {
    this.yourService.test();
  }
}

控制器通过调用服务方法来处理 HTTP 请求,并返回响应。

路由的设置

路由设置通过装饰器在控制器中定义,支持静态和动态路径。动态路径参数通过 @Param() 装饰器获取。例如:

typescript 复制代码
import { Controller, Get, Param } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Get(':id')
  findOne(@Param('id') id: string): string {
    return `This action returns a #${id} cat`;
  }
}

访问 /cats/1 时,findOne 方法返回 This action returns a #1 cat

在 Nest.js 中,@Get()@Post() 是两个常用的装饰器,它们分别用来处理 HTTP 的 GET 和 POST 请求。

@Get()

当客户端向服务器发送 GET 请求时,Nest.js 会调用使用了 @Get() 装饰器的方法来处理这个请求。

typescript 复制代码
import { Controller, Get } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Get()
  findAll(): string {
    return 'This action returns all cats';
  }
}

在上面的例子中,当客户端向 /cats 发送 GET 请求时,findAll() 方法会被调用,并返回所有猫咪的信息。

@Post()

当客户端向服务器发送 POST 请求时,Nest.js 会调用使用了 @Post() 装饰器的方法来处理这个请求。

typescript 复制代码
import { Controller, Post } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Post()
  create(): string {
    return 'This action adds a new cat';
  }
}

发送 POST 请求到 /cats 时,create() 方法被调用,添加新猫咪。

相关推荐
无限大.1 小时前
前端知识速记:节流与防抖
前端
十八朵郁金香1 小时前
【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能
前端·javascript·vue.js
学问小小谢1 小时前
第26节课:内容安全策略(CSP)—构建安全网页的防御盾
运维·服务器·前端·网络·学习·安全
LCG元2 小时前
Vue.js组件开发-实现全屏图片文字缩放切换特效
前端·javascript·vue.js
还是鼠鼠3 小时前
图书管理系统 Axios 源码__新增图书
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
还是鼠鼠6 小时前
图书管理系统 Axios 源码 __删除图书功能
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
轻口味6 小时前
Vue.js `Suspense` 和异步组件加载
前端·javascript·vue.js
m0_zj7 小时前
8.[前端开发-CSS]Day08-图形-字体-字体图标-元素定位
前端·css
还是鼠鼠8 小时前
图书管理系统 Axios 源码__编辑图书
前端·javascript·vscode·ajax·前端框架
北极象8 小时前
vue3中el-input无法获得焦点的问题
前端·javascript·vue.js