繁体   English   中英

tsyringe - 使用重载的构造函数注入依赖项

[英]tsyringe - Injecting a dependency with overloaded constuctor

嗨朋友你好吗?

我正在尝试做一些不同的事情,我不知道它是否偏离了概念本身,但它会帮助我以一种优雅的方式实现我想要做的事情。

我正在使用存储库模式,在实现中我想使用重载的构造函数并使用可选参数,基本上在需要时传递一些 adicional 信息。

问题是,当构造函数为空时它工作得很好,但是当更改签名以接收更多参数时,TSYSRINGE 会抛出一个异常。

我真的认为我错过了一些非常简单的东西,但我不知道是什么。 你能帮我解决这个问题吗? 谢谢

错误:

Error: Cannot inject the dependency at position #0 of "ListProjectsServices" constructor. Reason:
    TypeInfo not known for "ProjectsRepository"

Controller

export default class ProjectsController {
  public async index(request: Request, response: Response): Promise<void> {
    const listProjectsServices = container.resolve(ListProjectsServices);
    const projects = await listProjectsServices.execute();
    response.json(projects);
  }

服务

@injectable()
export default class ListProjectsServices {

  constructor(
    @inject('ProjectsRepository')
    private ProjectsRepository: IProjectsRepository,
  ) {}

  public async execute(): Promise<Projects[]> {
    const ProjectsList = await this.ProjectsRepository.findAllProjects();
    return ProjectsList;
  }
}

容器 - 创建注入令牌


container.registerSingleton<IProjectsRepository>(
  'ProjectsRepository',
  ProjectsRepository,
);

Repository - 注意构造函数中的 extra_details 参数

添加后出现问题


@EntityRepository(Projects)
export default class ProjectsRepository implements IProjectsRepository {
  private ormRepository: Repository<Projects>;

  constructor(extra_details?: object) {
    this.ormRepository = getRepository(Projects);
  }
[...]

今天我遇到了同样的问题。 阅读文章的循环依赖。 它告诉我们使用从 tsyringe 导入的延迟函数。 在文章中,他告诉我们在构造函数内部使用延迟。 但是你和我一样,不是直接在注入中发送对象,而是一个注册的密钥。 然后你必须在你的容器文件中使用延迟,在存储库对象周围试试这个:

import { container, delay } from 'tsyringe';

container.registerSingleton<IProjectsRepository>(
  'ProjectsRepository',
  delay(() => ProjectsRepository),
);

在依赖于异步存储库的所有注入中插入延迟

它也可能是 seo ormconfig.json 实体属性中的错误。 确保路径指向您的实体:

"entities": [
  "./src/modules/**/infra/typeorm/entities/*.ts"
],

我们在这里遇到了同样的问题,我们不想在 controller 中使用延迟 function 因为我们会破坏依赖注入原则......解决问题的一种方法是将“容器”文件导入主项目文件,在我们的例子中称为“server.ts”并安装一个名为“reflect-metadata”的库。

服务器.ts:

import * as dotenv from 'dotenv';

dotenv.config();

import express from 'express';
import 'express-async-errors';
import 'reflect-metadata'; // here is reflect-metadata import!
import config from './config/application';
import './infra/container'; // here is container import!
import { errorHandler } from './infra/http/middlewares/errorHandler';
import useSwagger from './infra/http/middlewares/swagger';
import { routes } from './infra/http/routes';
import { morganMiddleware } from './infra/logging/morgan';

export const app = express();

app.use(morganMiddleware);
app.use(express.json());
app.use(`${config.prefix}/api`, routes);
app.use(`${config.prefix}`, express.static('public'));
useSwagger(`${config.prefix}/api/docs`, app);
app.all(`${config.prefix}`, (_, res) => res.redirect(`${config.prefix}/api/docs`));
app.use(errorHandler);

容器/index.ts:

import { container } from 'tsyringe';
import { RecurrenceNotificationUseCase } from '../../application/useCases/RecurrenceNotificationUseCase';
import { PubSubImplementation } from '../pubsub/PubSubImplementation';

container.registerSingleton('IPubSub', PubSubImplementation);
container.registerSingleton('IRecurrenceNotificationUseCase', RecurrenceNotificationUseCase);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM