JavaScript classes are a way to create reusable object blueprints. Classes allow you to define the structure and behavior of objects, making your code more organized and easier to maintain. In this guide, we'll explore how to create JavaScript classes and provide examples to illustrate their usage.


Defining a JavaScript Class


To create a JavaScript class, you can use the class keyword, followed by the class name. Within the class, you can define properties and methods:


class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
greet() {
console.log(`Hello, my name is ${this.name} and I'm ${this.age} years old.`);
}
}

In this example, we've defined a Person class with a constructor and a greet method. The constructor initializes the object's properties, and the greet method logs a greeting.


Creating Instances of a Class


Once a class is defined, you can create instances (objects) of that class using the new keyword:


const person1 = new Person("Alice", 30);
const person2 = new Person("Bob", 25);
person1.greet(); // Outputs: "Hello, my name is Alice and I'm 30 years old."
person2.greet(); // Outputs: "Hello, my name is Bob and I'm 25 years old."

We've created two Person objects, person1 and person2, with different values for the name and age properties. Then, we called the greet method on each object to display a personalized greeting.


Class Inheritance


JavaScript supports class inheritance, allowing you to create a subclass (child class) that inherits properties and methods from a parent class (superclass). You can use the extends keyword to define a subclass:


class Student extends Person {
constructor(name, age, grade) {
super(name, age); // Call the constructor of the parent class
this.grade = grade;
}
study() {
console.log(`${this.name} is studying in grade ${this.grade}.`);
}
}
const student = new Student("Eve", 15, 9);
student.greet(); // Outputs: "Hello, my name is Eve and I'm 15 years old."
student.study(); // Outputs: "Eve is studying in grade 9."

In this example, the Student class extends the Person class. It calls the parent class constructor using super() and introduces its own property and method. An instance of Student inherits the properties and methods from both classes.


Conclusion


JavaScript classes provide a structured way to create and manage objects in your code. With classes, you can define the blueprint of objects and create instances with consistent properties and behavior. Understanding class inheritance further empowers you to build complex hierarchies of objects in your applications.


Happy coding with JavaScript classes!