ใช่คนแรกเป็นstatic methodที่เรียกว่าในขณะที่คนที่สองเป็นclass methodinstance 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เป็นวิธีการแบบคงที่ในขณะที่เป็นวิธีการที่ตัวอย่างของsayHiPerson
ด้านล่างเป็นวิธีการสร้างวัตถุจากตัว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}`;
}
}
ดูที่วิธีการคำหลักที่ถูกใช้ในการประกาศวิธีการคงstaticisPerson
เพื่อสร้างวัตถุ Personคลาส
const aminu = new Person("Aminu", "Abubakar");
ใช้วิธีการคงที่ isPersonโดยใช้วิธีการแบบคงที่
Person.isPerson(aminu); // will return true
ใช้วิธีการอินสแตนซ์ sayHiโดยใช้วิธีการเช่น
aminu.sayHi(); // will return "Hi Aminu"
หมายเหตุ:ทั้งสองตัวอย่างนั้นโดยพื้นฐานแล้วจาวาสคริปต์ยังคงเป็นภาษาที่ไม่มีคลาส การclassแนะนำในES6นั้นส่วนใหญ่เป็นน้ำตาลในรูปแบบ syntax มากกว่าต้นแบบที่มีอยู่เดิม