Classes Genéricas no TypeScript
Além de interfaces genéricas no TypeScript, também é possível criar classes genéricas.
Vamos criar uma classe User de um tipo
genérico. Vamos também escrever uma propriedade value
do tipo genérico e criar um construtor
correspondente:
class User <T> {
value: T;
constructor(userData: T) {
this.value = userData;
}
}
Agora vamos criar um objeto desta classe e atribuir um valor do tipo string à sua propriedade:
let user = new User('john');
console.log(user.value); // 'john'
No entanto, se já tivermos definido um valor de string para o objeto durante sua invocação, não será possível sobrescrever esse valor com outro tipo:
let user = new User('john');
user.value = 35;
Ao tentar executar o código, veremos o seguinte erro:
Type 'number' is not assignable to type 'string'.
Mas, ao mesmo tempo, podemos sobrescrever o valor de string:
let user = new User('john');
user.value = 'alex';
console.log(user.value); // 'alex'
Observe que não podemos sobrescrever a propriedade do mesmo objeto com outro tipo, mas podemos simplesmente criar outro objeto:
let newUser = new User(35);
console.log(newUser.value); // 35