babeljs类在构造函数中的静态

时间:2016-08-25 21:36:00

标签: javascript babel-6

问题是如何在调用 super 方法之前从构造函数中访问类静态属性

class A
{
    constructor(input) {
        console.log('A', typeof new.target);
    }
}

class B extends A
{
    static template = '';

    constructor() {
        console.log('B', typeof new.target);
        super();
    }
}

class C extends B
{
    static template = 'CCC';
}

new C();

出于某种原因,我得到了:

B undefined
A undefined

而不是

B function
A function

大约一年前我already asked this question。目前,其中提供的解决方案已不再可行。

您可以尝试babel console中的代码。有趣的是,这段代码在没有babel的情况下工作正常(例如在最新的Chrome中),当 es2015 复选框关闭时。

1 个答案:

答案 0 :(得分:1)

这似乎是巴贝尔的一个错误。我写了一个小插件,它转换为 new.target

https://github.com/vbarbarosh/babel_plugin_transform_es2015_newtarget

$ npm install --save-dev git://github.com/vbarbarosh/babel_plugin_transform_es2015_newtarget
$ cat .babelrc
...
    "plugins": ["transform-es2015-newtarget"],
...