class DateComponent {
constructor(public months:string[] = [],public days:number[] = [] , public years:number[] = []) { }
};
这让我在Chrome中出错。说“=”无效。我正在使用angular 2和typescript以及webpack dev服务器。
如何将值传递给构造函数中的参数?
答案 0 :(得分:0)
就像Harry在评论中所说的那样,在构造函数中定义类成员是为Angular 2中的依赖注入保留的。
我建议将它们移出构造函数:
class DateComponent {
public months: Array<string> = [];
public days: Array<string> = [];
public years: Array<string> = [];
constructor() {
}
}
答案 1 :(得分:0)
如果你想要构造函数的可选参数,你必须添加“?”。 但是对象的参数必须在构造函数之外定义。
在angular2中,你会看到一些参数在构造函数中定义,但这在注释(@ Component,@ Direction,...)中有用,它将那里定义为类属性。
如果我理解正确你想要这样的东西:
class DateComponent {
public months: [] = [];
public days: [] = [];
public years: [] = [];
constructor(_months?:string[],_days?:number[], _years?:number[]) {
this.months = _months;
this.days = _days;
this.years = _years;
}
};