为什么我得到一个' TypeError:undefined不是一个函数'这里?

时间:2015-05-28 09:58:21

标签: node.js typescript commonjs typescript1.5

尝试运行下面指定的代码时,我遇到了一个奇怪的(对我而言)错误。代码编译得很好,但是当我运行它时,node返回这个错误:

<location>/C.js:11
    _super.call(this, "C");
           ^
TypeError: undefined is not a function
    at new C (<location>/C.js:11:16)
    at Function.B.factory (<location>/B.js:15:17)
    at Function.Test.test (<location>/Test.js:6:18)
    at Object.<anonymous> (<location>/app.js:2:6)
    at Module._compile (module.js:460:26)
    at Object.Module._extensions..js (module.js:478:10)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Function.Module.runMain (module.js:501:10)
    at startup (node.js:129:16)

编译命令:tsc --module commonjs -t ES5 app.ts

使用运行:node app.js

显然我不熟悉Typecript和Javascript,但我不知道为什么会失败。我已经四处寻找解决方案但是虽然这似乎是一个常见的问题,但我对于我的特定问题却是空洞的。任何人都可以阐明为什么会发生这种情况?以下是文件:

A.ts

class A {
    constructor(private name: string) {}
}
export = A;

B.ts

import A = require('./A');
import C = require('./C');

class B extends A {
    constructor(value: string) {
        super(value);
    }
    public static factory() {
        var a: A = new C();
        return a;
    }
}
export = B;

C.ts

import B = require('./B');

class C extends B {
    constructor() {
        super("C");
    }
}
export = C;

Test.ts

import B = require('./B');

class Test {
    public static test() {
        return B.factory();
    }
}
export = Test;

app.ts

///<reference path='./typings/node/node.d.ts' />
import Test = require('./Test');
Test.test();

为了节省一些空间,我粘贴了生成的javascript代码。如果您有兴趣,可以在此处找到:javascript dump

1 个答案:

答案 0 :(得分:2)

这是因为你有一个循环依赖。 C取决于BB取决于C。因此,B根据规范未定义。 https://nodejs.org/api/modules.html#modules_cycles