Да, первый static method
также называется class method
, а второй - instance method
.
Рассмотрим следующие примеры, чтобы понять это более подробно.
В ES5
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
Person.isPerson = function(obj) {
return obj.constructor === Person;
}
Person.prototype.sayHi = function() {
return "Hi " + this.firstName;
}
В приведенном выше коде isPerson
это статический метод, а sayHi
метод экземпляра Person
.
Ниже описано, как создать объект из Person
конструктора.
var aminu = new Person("Aminu", "Abubakar");
Используя статический метод isPerson
.
Person.isPerson(aminu); // will return true
Используя метод экземпляра sayHi
.
aminu.sayHi(); // will return "Hi Aminu"
В ES6
class Person {
constructor(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
static isPerson(obj) {
return obj.constructor === Person;
}
sayHi() {
return `Hi ${this.firstName}`;
}
}
Посмотрите, как static
ключевое слово использовалось для объявления статического метода isPerson
.
Создать объект Person
класса.
const aminu = new Person("Aminu", "Abubakar");
Используя статический метод isPerson
.
Person.isPerson(aminu); // will return true
Используя метод экземпляра sayHi
.
aminu.sayHi(); // will return "Hi Aminu"
ПРИМЕЧАНИЕ. Оба примера по сути одинаковы, JavaScript остается бесклассовым языком. Представленный class
в ES6 является в первую очередь синтаксическим сахаром по сравнению с существующей моделью наследования на основе прототипов.