Да, первый 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 является в первую очередь синтаксическим сахаром по сравнению с существующей моделью наследования на основе прототипов.