如何在ES Next中扩展静态属性?

Chr*_*ris 4 javascript ecmascript-next

有时(尽管很少)你需要扩展,而不是覆盖父静态属性,例如下面的(非常蹩脚)示例:

class Person {
    static coreStats = {
        role: "slacker",
        weapon: null,
        speed: 4,
        vechicle: "roller blades",
    };
}

class Ninja extends Person {
    static coreStats = {
        role: "silent assassin",
        weapon: "katana",
        speed: 99,
    };
}

console.log(Ninja.coreStats); // But vechicle is no more
Run Code Online (Sandbox Code Playgroud)

如何在不破坏父属性的情况下扩展子类中的静态属性?

Dmi*_*rov 5

你可以这样做:

class Person {
    static coreStats = {
        role: "slacker",
        weapon: null,
        speed: 4,
        vechicle: "roller blades",
    };
}

class Ninja extends Person {
    static coreStats = Object.assign({}, Person.coreStats, {
        role: "silent assassin",
        weapon: "katana",
        speed: 99
    });
}
console.log(Ninja.coreStats);
Run Code Online (Sandbox Code Playgroud)

这将合并coreStats,并覆盖Person.coreStatsNinja.coreStats在重复的情况下,