我正在尝试将 inversify 与 typescript 和 node.js 一起使用。我目前正在使用 node.js 版本 6.9.1、typescript 版本 2.6.2 和 ECMAScript 6。当我尝试运行 node.js 应用程序时,我不断收到以下错误,“TypeError: Reflect.hasOwnMetadata is not a function ”。
按照我在网上找到的文档,通过在 inversify.config.js 文件的顶部添加 import "reflect-matadata",它似乎工作了一段时间,但现在问题又回来了。
在我的 inversify.config.ts 文件中,我有以下从我的 app.ts 文件中调用的代码:
export let initialize = async (): Promise<Container> => {
var container = new Container();
try {
if (!Reflect.hasOwnMetadata("inversify:paramtypes", ClassToAddInjectableTo)) {
decorate(injectable(), ClassToAddInjectableTo);
}
….
container.bind<interfaces.Controller>(TYPE.Controller).to(MyController1).whenTargetNamed('MyController1');
container.bind<interfaces.Controller>(TYPE.Controller).to(MyController2).whenTargetNamed('MyController2');
} catch (ex) {
throw ex;
}
}
此代码存在于 app.ts 中,它调用 inversify.config.ts 文件中的代码:
setup = async () => {
try {
let container: Container = await initialize();
…..
} catch (err){
throw err;
}
}
问题似乎在 node_modules/inversify/lib/annotation/decorator_utils.js:22 中的以下行:
if (Reflect.hasOwnMetadata(metadataKey, annotationTarget) === true) {
在生成的 inversify.config.js 文件中,以下代码似乎在 import "reflect-metadata" 的上方:
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
require("reflect-metadata");
我注意到我在网上找到的帮助只表明我需要添加导入“reflect-metadata”。
另外,这是我的 tsconfig.json 文件:
{
"compilerOptions": {
"module": "commonjs",
"target": "ES6",
"moduleResolution": "node",
"experimentalDecorators": true,
"emitDecoratorMetadata": true,
"types": ["reflect-metadata"],
"lib": ["ES6"],
"sourceMap": true,
"inlineSources": true,
"pretty": true,
"outDir": "dist",
"rootDir": "src",
"noLib": false,
"declaration": true
},
"include": [
"src/**/*"
],
"exclude": [
"node_modules"
]
}
有人可以查看并让我知道我可能会丢失什么吗?
更新:对于上述问题,我将导入“reflect-metadata”添加到文件 inversify.config.ts 文件中。但是,我评论了这个导入语句并将导入“reflect-metadata”添加到 app.ts 文件中,现在我得到了一个不同的错误:
throw new Error(ERRORS_MSGS.DUPLICATED_INJECTABLE_DECORATOR);
^
Error: Cannot apply @injectable decorator multiple times.
现在我在互联网上发现了一个帖子,似乎描述了添加导入“reflect-metadata”添加了一个 Reflect 全局变量。另外,我不知道这是否有帮助,但我从控制器中删除了 @injectable 装饰器。