Generičke klase u TypeScript-u
Pored generičkih interfejsa u TypeScript-u možemo praviti i generičke klase.
Hajde da napravimo klasu User generičkog
tipa. Napišimo takođe svojstvo value
generičkog tipa i napravimo odgovarajući
konstruktor:
class User <T> {
value: T;
constructor(userData: T) {
this.value = userData;
}
}
Sada napravimo objekat ove klase i dodelimo mu string vrednost u svojstvo:
let user = new User('john');
console.log(user.value); // 'john'
Međutim, ako smo već dodelili string vrednost objektu prilikom njegovog kreiranja, nećemo moći da prepišemo tu vrednost drugim tipom:
let user = new User('john');
user.value = 35;
Prilikom pokušaja pokretanja koda videćemo sledeću grešku:
Type 'number' is not assignable to type 'string'.
Ali u isto vreme možemo prepisati string vrednost:
let user = new User('john');
user.value = 'alex';
console.log(user.value); // 'alex'
Primetite da ne možemo prepisati svojstvo tog istog objekta drugim tipom, ali možemo napraviti potpuno drugi objekat:
let newUser = new User(35);
console.log(newUser.value); // 35