一次搞定Nest装饰器

前言


🐔我们正在写Nest的时候会发现我们不论是实现IOC还是AOP的架构又或者声明接口的路由我们使用的都是装饰器,Nest给我们提供了很多装饰器,我们可以使用装饰器来很方便的实现一些功能,这篇文章就一次性搞定Nest中所有的装饰器~

一.@Module


😳@Module用来声明Nest中的模块。

二.@Controller


🤣@Controller装饰器主要用来声明Nest中的controller

三.@Injectable


😳@Injectable表示当前模块是可以被注入的,一般用来声明Service层,并且service会出现在Module中的provider数组中便是这个东西被提供出来了,可供其他模块或者controller注入使用。

四.@Inject


🙈@Inject表示一个注入的动作,我们知道在controller中注入service的时候有两种注入方式,一种是在构造函数中注入,另一种是通过属性@Inject的方式注入的。

五.@Optional


🐻‍❄️@Optional的作用是当在注入的时候提供者并没有提供这个数据按照正常的情况代码是会报错的,但是这个可选装饰器就类似与TS中的可选的操作。

六.@Catch


🐸我们处理异常是使用ExceptionFilter这个方式,当抛出异常的时候我们就进行相应的处理,而@Catch可以处理指定的异常

七.@UseFilters/Use*


🐣当我们使用了上述异常处理的方式之后我们可以将错误处理应用到具体接口上去(handler)然后接口收到请求就会通过TestFilter

🐲除了UseFilters之外其他几个例如UseGuards``UseInterceptors等等都是这么使用的

八.@Query/@Param


😗@Query 是取 url 后的 ?bbb=true,而 @Param 是取路径中的参数,比如 /xxx/111 种的 111

九.@Body


🦝@Body就是如果是POST请求的话就可以通过这个装饰器来取到body中的值,另外除了 @Get、@Post 外,还可以用 @Put、@Delete、@Patch、@Options、@Head 装饰器分别接受 put、delete、patch、options、head 请求:

十.@SetMetadata


🐔handler 和 class 可以通过 @SetMetadata 指定 metadata,然后在 guard 或者 interceptor 里取出来。

十一.@Headers


😳@Headers 装饰器取某个请求头 或者全部请求头。

十二.@Ip


🙈@Ip 拿到请求的 ip

十三.Nest中的全部装饰器


less 复制代码
@Module: 声明 Nest 模块
@Controller:声明模块里的 controller
@Injectable:声明模块里可以注入的 provider
@Inject:通过 token 手动指定注入的 provider,token 可以是 class 或者 string
@Optional:声明注入的 provider 是可选的,可以为空
@Global:声明全局模块
@Catch:声明 exception filter 处理的 exception 类型
@UseFilters:路由级别使用 exception filter
@UsePipes:路由级别使用 pipe
@UseInterceptors:路由级别使用 interceptor
@SetMetadata:在 class 或者 handler 上添加 metadata
@Get、@Post、@Put、@Delete、@Patch、@Options、@Head:声明 get、post、put、delete、patch、options、head 的请求方式
@Param:取出 url 中的参数,比如 /aaa/:id 中的 id
@Query: 取出 query 部分的参数,比如 /aaa?name=xx 中的 name
@Body:取出请求 body,通过 dto class 来接收
@Headers:取出某个或全部请求头
@Session:取出 session 对象,需要启用 express-session 中间件
@HostParm: 取出 host 里的参数
@Req、@Request:注入 request 对象
@Res、@Response:注入 response 对象,一旦注入了这个 Nest 就不会把返回值作为响应了,除非指定 passthrough 为true
@Next:注入调用下一个 handler 的 next 方法
@HttpCode: 修改响应的状态码
@Header:修改响应头
@Redirect:指定重定向的 url
@Render:指定渲染用的模版引擎

十四.总结


🐔Nest中有非常多的装饰器,我们在进行Nest开发的时候会使用的非常的频繁,在一定意义上讲掌握了装饰器就基本掌握了Nest的开发技能~

相关推荐
陈橘又青9 分钟前
100% AI 写的开源项目三周多已获得 800 star 了
人工智能·后端·ai·restful·数据
2501_9411486135 分钟前
C++实时数据处理实战:多线程与异步IO结合高性能代码解析
java·后端·struts
IT_陈寒1 小时前
Redis实战:5个高频应用场景下的性能优化技巧,让你的QPS提升50%
前端·人工智能·后端
mzlogin1 小时前
借助 Let's Encrypt 节省 SSL 证书费用
后端·devops
虎子_layor1 小时前
单机压测从百到三千:一次短链跳转服务的全链路性能优化实战
后端·性能优化
SelectDB1 小时前
Apache Doris 中的 Data Trait:性能提速 2 倍的秘密武器
数据库·后端·apache
zhengzizhe1 小时前
LangGraph4j LangChain4j JAVA 多Agent编排详解
java·后端
程序员鱼皮2 小时前
又被 Cursor 烧了 1 万块,我麻了。。。
前端·后端·ai·程序员·大模型·编程
福大大架构师每日一题2 小时前
2025-11-27:为视频标题生成标签。用go语言,给定一个字符串 caption(视频标题),按下面顺序处理并输出一个标签: 1. 将标题中的各个词合并成一
后端
程序员爱钓鱼2 小时前
Go语言 OCR 常用识别库与实战指南
后端·go·trae