【发布时间】:2020-09-08 17:16:12
【问题描述】:
我有以下代码:
export class A {
parent?: string;
constructor(attrs: object = {}) {
Object.assign(this, attrs);
}
}
export class B extends A {
public child?: string;
}
console.log(new B({parent: "1", child: "2"}));
// Results in:
// Object {parent: "1", child: undefined}
父类中的Object.assign 没有设置子类中的任何属性。我不想为每个调用 super 和另一个 Object.assign 的子类指定构造函数。
有没有办法使用父类中的单个方法为子类分配所有属性,不必明确指定每个属性?
【问题讨论】:
-
我无法重现您的问题。 Ctrl+Enter 并检查控制台,它看起来很好:typescript-play.js.org/?target=2#code/…
-
我似乎无法解决您的问题:jsfiddle.net/9h27nqLo。请注意,您的方法不是防弹的:尽管没有声明,您仍然可以在
A类中创建一个新的child成员。 -
嗯,我会翻转一些编译器标志,看看是否有任何变化。
-
也许您正在使用
undefined显式初始化该字段? Inituslizers 在基类构造函数之后运行 -
我刚刚又做了一次
create-react-app,用npm install typescript添加了打字稿,添加了相同的tsconfig.json,将两个类添加到test.ts和console.log到index.js,我又遇到了同样的问题。我现在的猜测是:1)create-react-app 配置有一些我不知道的东西,2)我的tsconfig有一些奇怪的设置。
标签: javascript typescript