评估类构造函数

时间:2017-08-23 22:29:50

标签: javascript angular typescript

在创建一个以对象作为参数的实例后,我想实现两件事:

首先,迭代参数的属性并将其添加到实例中,如果它完全与在构造函数上方声明的此属性方式相同的类型。有没有快速的方法,我必须逐一检查这个吗?

其次,我想检查是否定义了每个声明的属性,如果没有,则设置默认值。

var data = {
  langs: ["de","en","fr"],
  lesson: {
    de: "Einführung",
    en: "Introduction"
  },
  keywords: []
}

class Video {
  langs: Array<string>;
  lesson: object;
  topic: object;
  intro: object;
  keywords: Array<Keyword>;

  constructor (data) {
    for (let prop in data) {
      if (/*data.s is of type as declared above constructor()*/) {
        this[prop] = data[prop];
      } else {
        throw "Type of {{prop}} is invalid";
      }
    }
    for (let prop in /*All the props defined above constructor()*/) {
      if (!this.hasOwnProperty(prop)) {
        //Set default value;
      }
    }
  }
}

var video = new Video(data);

1 个答案:

答案 0 :(得分:0)

  

有一种快速的方法吗?我必须逐一检查吗?

使用类型注释,例如改变

constructor (data) {

constructor (data: { langs : string[] /* so on */}) {
  

我想检查是否定义了每个声明的属性,如果没有,则设置默认值。

使用strictNullChecks将逻辑移出代码:https://basarat.gitbooks.io/typescript/content/docs/options/strictNullChecks.html