类构造函数angular 2的默认数组值

时间:2016-10-06 09:01:49

标签: javascript angular typescript

class DateComponent {
  constructor(public months:string[] = [],public days:number[] = [] , public years:number[] = []) { }

};

这让我在Chrome中出错。说“=”无效。我正在使用angular 2和typescript以及webpack dev服务器。

如何将值传递给构造函数中的参数?

2 个答案:

答案 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;
     }

    };