Introduction

Inheritance is a fundamental concept in Object-Oriented Programming (OOP) that allows you to create a new class by inheriting properties and methods from an existing class. TypeScript supports single inheritance and provides a mechanism to extend classes. In this guide, we'll explore how to use inheritance in TypeScript to create derived classes that inherit from base classes.


Defining a Base Class

A base class, also known as a superclass, serves as the template for creating derived classes. It defines properties and methods that are shared by the derived classes.


Example:

class Animal {
name: string;
constructor(name: string) {
this.name = name;
}
makeSound() {
console.log(this.name + " makes a sound.");
}
}

Extending a Class

To create a derived class, you use the extends keyword, which indicates that the new class should inherit from an existing class (base class).


Example:

class Dog extends Animal {
breed: string;
constructor(name: string, breed: string) {
super(name);
this.breed = breed;
}
makeSound() {
console.log(this.name + " barks loudly.");
}
}
const myDog = new Dog("Fido", "Golden Retriever");

Calling Superclass Constructor

In the derived class constructor, you can call the constructor of the superclass using super() to initialize properties defined in the base class.


Method Overriding

Derived classes can override methods from the base class. This means that they provide their own implementation of a method, which is used when the method is called on an object of the derived class.


Example:

class Cat extends Animal {
constructor(name: string) {
super(name);
}
makeSound() {
console.log(this.name + " purrs softly.");
}
}
const myCat = new Cat("Whiskers");

Conclusion

Inheritance is a powerful mechanism in TypeScript that allows you to create new classes based on existing ones, promoting code reuse and maintaining a hierarchical structure. By extending classes and using method overriding, you can create complex class hierarchies to model real-world entities and behaviors in your applications.