一次搞定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的开发技能~

相关推荐
杨凯凡5 小时前
【021】反射与注解:Spring 里背后的影子
java·后端·spring
Ares-Wang6 小时前
Flask》》 Flask-Bcrypt 哈希加密
后端·python·flask
小码哥_常6 小时前
Spring Boot项目大变身:为何要拆成这六大模块?
后端
码事漫谈8 小时前
兵临城下:DeepSeek-V4 的技术突围与算力“成人礼”
后端
三水不滴8 小时前
SpringAI + SpringDoc + Knife4j 构建企业级智能问卷系统
经验分享·spring boot·笔记·后端·spring
玖玖passion9 小时前
Windows 上部署 Hermes Agent 完整指南 - 让你的 AI 助手在 WSL2 中跑起来
前端·后端·github
Undoom10 小时前
【腾讯位置服务开发者征文大赛】基于YOLOv8与腾讯地图的视障辅助Android应用——从模型训练到端侧部署全链路实践
后端
ltl10 小时前
【大模型基础设施工程】03:CUDA 生态——cuBLAS、cuDNN、NCCL、Triton、CUTLASS
后端
wan_jm11 小时前
Go Web 开发提速 3(gos):Filter 实战与变量注入 —— 通用逻辑复用与依赖解耦
后端