Setterji navideznih lastnosti v OOP v JavaScript
Poleg getterjev navideznih lastnosti lahko ustvarimo tudi njihove setterje. V tem primeru moramo znotraj setterja prejeti podatke, jih razdeliti in zapisati ustrezne dele v ustrezne javne lastnosti.
Poskusimo. Implementirajmo
setter navidezne lastnosti full:
class User {
constructor(name, surn) {
this.name = name;
this.surn = surn;
}
get full() {
return this.name + ' ' + this.surn;
}
set full(full) {
let [name, surn] = full.split(' ');
this.name = name;
this.surn = surn;
}
}
Poenostavimo destrukturiranje:
class User {
constructor(name, surn) {
this.name = name;
this.surn = surn;
}
get full() {
return this.name + ' ' + this.surn;
}
set full(full) {
[this.name, this.surn] = full.split(' ');
}
}
Ustvarimo objekt razreda:
let user = new User('john', 'smit');
Zapišimo podatke v naš navidezni setter:
user.full = 'eric jons';
Preverimo, ali so se lastnosti objekta spremenile:
console.log(user.name); // 'eric'
console.log(user.surn); // 'jons'
console.log(user.full); // 'eric jons'