Статические свойства в 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. Выведите данное свойство без объявления объекта.



Чат с GPT Компилятор