Абагульненыя класы ў 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