打字稿,如何将对象传递给类的构造函数进行实例化

2023-11-21

我有一个从后端 api 获取的数组对象数据。喜欢:

[
 {name: 'react', age: 4},
 {name: 'angular', age: 4},
 ...
 {name: 'rxjs', age: 2}
]

我确定一个class and an interface, 像这样:

interface IBook {
  name: string;
  age: number;
}

class Book{
  book: IBook;

  constructor(book: IBook) {
    this.book = book;
  }

  //I can definite some method here: 

  getFullName() {
    return this.book.firstName + ' ' + this.book.lastName;
  }

  isValid() {
    return book.name.length > 0;
  }

}

//when get the data
const dataModels = datas.map(data => {
  return new Book(data);
});

所以我可以封装一些数据模型方法,例如book.getFullName()

我可以这样使用它:

const fullname = book.getFullName()

而不是这个:

const fullname = book.firstName + ' ' + book.lastName;

有一个更好的方法吗? 我不确定我的想法是否正确。

问题是如何转换js反对ts按照正确的方式进行类模型。

或者,只是确定数据interface。是否需要转换javascriptjson 数据到typescript class model?

- 更新 -

特别是嵌套数据。像这样:

const datas = [
 {name: 'react', age: 2, tag: [{id: 1}, {id: 2}]}
]

如果不需要任何方法,只需转换您的数据即可。否则,您可以将数据复制到您的班级。

let datas = [
 {name: 'react', age: 4, extra: { value: 1 }},
 {name: 'angular', age: 4, extra: { value: 2 }},
 {name: 'rxjs', age: 2, extra: { value: 3 }}
]

interface IBook {
  name: string;
  age: number;
}

interface Extra {
    value: number;
}

let books: IBook[] = datas;
console.log(books[0].name); // react

class Book {
    name: string;
    age: number;
    extra: Extra;

    constructor(data: any) {
        for (let key in data) {
            this[key] = data[key];
        }
    }

    getFullName() {
        return this.name;
    }

    isValid() {
        return this.name.length > 0;
    }
}

let books2 = datas.map(book => new Book(book));
console.log(books2[1].getFullName()); // angular
console.dir(books2[0].extra.value); // 1
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

打字稿,如何将对象传递给类的构造函数进行实例化 的相关文章

随机推荐