Nest 循环依赖解决方案:forwardRef 的艺术

Nest 模块之间可以通过 imports 引用其他模块。

那 Module 和 Module 如果相互引用怎么办?

module 之间的循环依赖

创建一个 nest 项目:

bash 复制代码
nest new module-forward -p npm

创建两个 Module:

bash 复制代码
nest g module a
nest g module b

这种相互引用的情况就会报错。

使用 forwardRef 包装函数,该函数返回模块或提供者的引用,而不是直接引用,从而延迟了依赖项的解析:

这时候就没有报错了。

provider 循环依赖

bash 复制代码
nest g service c --no-spec --flat
nest g service d --no-spec --flat

两个 service 分别依赖了对方的方法。

这时候会报错,也是因为循环依赖导致的。

在提供者中通过 @Inject(forwardRef(() => Type)) 来注入依赖:

这样就不会报错了。

我们相互能不能正确获取结果,在 AppService 使用:

访问 localhost:3000:

没有问题。

合理的设计

  • 重新设计代码,避免循环依赖的产生是最好的做法。
  • 可以引入新的中间件、库或服务来分解复杂的依赖关系。
相关推荐
金銀銅鐵7 小时前
[Java] 从 class 文件看 cglib 对 MethodInterceptor 的处理 (下)
java·后端
Walter先生7 小时前
WebSocket 连接池生产级实现:实时行情高可用与负载均衡
后端·websocket·架构
踩着两条虫7 小时前
VTJ.PRO的平台介绍与特性
前端·架构·ai编程
光影少年7 小时前
前端工程化升级
前端·javascript·react.js·前端框架
Hello--_--World7 小时前
节流 VS 防抖 相关知识点与面试题
前端·javascript
We་ct7 小时前
AI辅助开发术语体系深度剖析
开发语言·前端·人工智能·ai·ai编程
去伪存真8 小时前
Superpowers 从“调教提示词”转向“构建工程规范”
前端·agent
skiy8 小时前
Spring Framework 中文官方文档
java·后端·spring
发现一只大呆瓜8 小时前
深度起底 Vite:从打包流程到插件钩子执行时序的全链路解析
前端·vite
jserTang8 小时前
Claude Code 源码深度解析 - 前言
前端·javascript·后端