如何在运行时获取父类

时间:2016-04-26 13:52:46

标签: typescript

是否可以在运行时获取TypeScript类的父类?我的意思是,例如,在装饰者中:

export function CustomDecorator(data: any) {
  return function (target: Function) {
    var parentTarget = ?
  }
}

我的自定义装饰器以这种方式应用:

export class AbstractClass {
  (...)
}

@CustomDecorator({
  (...)
})
export class SubClass extends AbstractClass {
  (...)
}

在装饰者中,我希望有一个AbstractClass的实例。

非常感谢你的帮助!

1 个答案:

答案 0 :(得分:8)

您可以使用Object.getPrototypeOf功能。

类似的东西:

class A {
    constructor() {}
}

class B extends A {
    constructor() {
        super();
    }
}

class C extends B {
    constructor() {
        super();
    }
}

var a = new A();
var b = new B();
var c = new C();

Object.getPrototypeOf(a); // returns Object {}
Object.getPrototypeOf(b); // returns A {}
Object.getPrototypeOf(c); // returns B {}

修改

After the code @DavidSherret添加(在评论中),这是你想要的(我认为):

export function CustomDecorator(data: any) {
  return function (target: Function) {
    var parentTarget = target.prototype;
    ...
  }
}

或者@DavidSherret指出:

function CustomDecorator(data: any) {
  return function (target: Function) {
    console.log(Object.getPrototypeOf(new (target as any)));
  }
}

第二次编辑

好的,所以我希望成为你的目标:

function CustomDecorator(data: any) {
    return function (target: Function) {
        var parentTarget = Object.getPrototypeOf(target.prototype).constructor;
        console.log(parentTarget === AbstractClass); // true :)
    }
}