该项目是带有TypeScript的NodeJS项目。
我想创建一个App类的实例。但是,如果使用new
关键字,则必须传递构造函数参数。
问题在于构造函数参数应该与依赖项注入一起传递。因此,我不能使用new
关键字创建实例。
// Express
import { application as app } from 'express';
// Controllers
import { UserController } from './controllers/user.controller'
export class App {
constructor(userController: UserController) {
console.log("App is running");
console.log("UserController url path is : ", userController.getUrlPath);
this.run();
}
run(): void {
app.listen(3000, function () {
console.log('App is running on port 3000!');
});
}
check(): void {
console.log("working well");
}
}
const appInstance: App = <App>Object.create(App.prototype); // it is not creating
console.log( appInstance.check() ); // ==> 'undefined'
最佳答案
这似乎与使用类的概念背道而驰
如果您需要避免通过具体的UserController
进行测试,则可以使用某种形式的模拟。
另一种选择是使用any
类型的变量:
const app = new App({} as any);
根据您的
tsconfig.json
配置,它应该可以工作(显然,您将无法访问UserController
对象的任何功能/字段,但是App
的构造应该可以正常工作。最后一个选项(至少可以想到)是对
UserController
使用setter函数:export class App {
private _userController: UserController;
get userController(): UserController {
return this._userController;
}
set userController(ctrl: UserController) {
this._userController = ctrl;
}
}
这样,在建立完整的DI基础结构之后,您可以使用
App.userController = SOME_USER_CONTROLLER_FROM_DI