Статические свойства в TypeScript
Давайте посмотрим, как обращаться к статическим свойствам внутри объектов.
Пусть у нас есть следующий класс со статическим свойством:
class User {
public name: string;
public static salary: number = 1000;
constructor(name: string) {
this.name = name;
}
}
Давайте теперь сделаем метод, выводящий общую зарплату:
class User {
public name: string;
public static salary: number = 1000;
constructor(name: string) {
this.name = name;
}
getSalary(): number {
return User.salary; // обращаемся по имени класса
}
}
Давайте теперь сделаем метод, изменяющий общую зарплату:
class User {
public name: string;
public static salary: number = 1000;
constructor(name: string) {
this.name = name;
}
getSalary(): number {
return User.salary;
}
setSalary(salary: number) {
User.salary = salary;
}
}
Статические свойства будут общими для разных объектов. Это значит, что при изменении свойства в одном объекте, оно поменяется в и другом. Проверим это.
Создадим два объекта нашего класса:
let user1: User = new User('john');
let user2: User = new User('eric');
Давайте поменяем зарплату для первого юзера:
user1.setSalary(2000);
Проверим, что зарплата изменилась и для второго юзера:
console.log(user2.getSalary()); // 2000
Проверим, что зарплата также изменилась в свойстве самого класса:
console.log(User.salary); // 2000
В класс Student
добавьте
статическое свойство university
.
Выведите данное свойство без объявления объекта.