Nest:常用 15 个装饰器知多少?

nest 很多功能基于装饰器实现,我们有必要好好了解下有哪些装饰器:

创建 nest 项目:

bash 复制代码
nest new all-decorator -p npm

@Module({})

这是一个类装饰器,用于定义一个模块。

模块是 Nest.js 中组织代码的单元,可以包含控制器、提供者等:

@Controller() 和 @Injectable()

这两个装饰器也是类装饰器,前者控制器负责处理传入的请求和返回响应,后者定义一个服务提供者,可以被注入到控制器或其他服务中。

通过 @Controller@Injectable 分别声明 controller 和 provider:

@Optional、@Inject

创建可选对象(无依赖注入),可以用 @Optional 声明一下,这样没有对应的 provider 也能正常创建这个对象。

注入依赖也可以用 @Inject 装饰器。

@Catch

filter 是处理抛出的未捕获异常,通过 @Catch 来指定处理的异常:

@UseXxx、@Query、@Param

使用 @UseFilters 应用 filter 到 handler 上:

除了 filter 之外,interceptor、guard、pipe 也是这样用:

@Body

如果是 post、put、patch** **请求,可以通过 @Body 取到 body 部分:

我们一般用 dto 定义的 class 来接收验证请求体里的参数。

@Put、@Delete、@Patch、@Options、@Head

@Put、@Delete、@Patch、@Options、@Head 装饰器分别接受 put、delete、patch、options、head 请求:

@SetMetadata

通过 @SetMetadata 指定 metadata,作用于 handler 或 class

然后在 guard 或者 interceptor 里取出来:

@Headers

可以通过 @Headers 装饰器取某个请求头或者全部请求头:

@Ip

通过 @Ip 拿到请求的 ip,通过 @Session 拿到 session 对象:

@HostParam

@HostParam 用于取域名部分的参数。

下面 host 需要满足 xxx.0.0.1 到这个 controller,host 里的参数就可以通过 @HostParam 取出来:

@Req、@Request、@Res、@Response

前面取的这些都是 request 里的属性,当然也可以直接注入 request 对象:

@Req 或者 @Request 装饰器,这俩是同一个东西。

使用 @Res 或 @Response 注入 response 对象,但是注入 response 对象之后,服务器会一直没有响应。

因为这时候 Nest 就不会把 handler 返回值作为响应内容了。我们可以自己返回响应:

Nest 这么设计是为了避免相互冲突。

如果你不会自己返回响应,可以设置 passthrough 为 true 告诉 Nest:

@Next

除了注入 @Res 不会返回响应外,注入 @Next 也不会。

当你有两个 handler 来处理同一个路由的时候,可以在第一个 handler 里注入 next,调用它来把请求转发到第二个 handler。

@HttpCode

handler 默认返回的是 200 的状态码,你可以通过 @HttpCode 修改它:

@Header

当然,你也可以修改 response header,通过 @Header 装饰器:

相关推荐
苏三说技术25 分钟前
LangChain4j 和 LangGraph4j,哪个更好?
后端
天蓝色的鱼鱼1 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
ServBay2 小时前
7 个AI开发中真正用得上的 MCP Server,配合Claude Code食用效果更佳
后端·claude·mcp
泯泷2 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花2 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷2 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜2 小时前
Spring Boot 核心知识点总结
前端
lichenyang4532 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
用户6757049885022 小时前
Go 语言里判断字符串为空,90% 的人都写错了!
后端·go
古夕2 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js