Защищенные свойства в ООП в JavaScript
Введем также и защищенные свойства. Будем также начинать их имена с подчеркивания. Посмотрим на примере. Сделаем класс-родитель с защищенным свойством, содержащим возраст:
class User {
setAge(age) {
this._age = age;
}
getAge() {
return this._age;
}
}
В классе потомке сделаем метод, увеличивающий возраст на единицу:
class Student extends User {
incAge() {
this._age++;
}
}
Перепишите следующий код через защищенное свойство:
class User {
#name;
setName(name) {
this.#name = name;
}
getName() {
return this.#name;
}
}
class Employee extends User {
setName(name) {
if (name.length > 0) {
this.#name = name;
}
}
}