Обобщенные классы в TypeScript
Помимо обобщенных интерфейсов в TypeScript можно делать и обобщенные классы.
Давайте создадим класс User обобщенного
типа. Напишем также свойство value
обобщенного типа и сделаем соответствующий
конструктор:
class User <T> {
value: T;
constructor(userData: T) {
this.value = userData;
}
}
Теперь сделаем объект данного класса и пропишем ему в свойство строчное значение:
let user = new User('john');
console.log(user.value); // 'john'
Однако, если мы уже задали объекту при его вызове строковое значение, у нас не получится перезаписать это значение в другой тип:
let user = new User('john');
user.value = 35;
При попытке запустить код мы увидим следующую ошибку:
Type 'number' is not assignable to type 'string'.
Но в то же время мы можем перезаписать строковое значение:
let user = new User('john');
user.value = 'alex';
console.log(user.value); // 'alex'
Заметьте, что перезаписать свойство того же самого объекта в другой тип мы не можем, но можем создать просто другой объект:
let newUser = new User(35);
console.log(newUser.value); // 35