Book Image

Refactoring TypeScript

By : James Hickey
Book Image

Refactoring TypeScript

By: James Hickey

Overview of this book

Refactoring improves your code without changing its behavior. With refactoring, the best approach is to apply small targeted changes to a codebase. Instead of doing a huge sweeping change to your code, refactoring is better as a long-term and continuous enterprise. Refactoring TypeScript explains how to spot bugs and remove them from your code. You’ll start by seeing how wordy conditionals, methods, and null checks make code unhealthy and unstable. Whether it is identifying messy nested conditionals or removing unnecessary methods, this book will show various techniques to avoid these pitfalls and write code that is easier to understand, maintain, and test. By the end of the book, you’ll have learned some of the main causes of unhealthy code, tips to identify them and techniques to address them.
Table of Contents (11 chapters)

Factory Functions

Sticking with our airplane example, we've got:

const plane = new Airplane();
plane.type = PlaneType.Passenger;
plane.engine = new PassengerPlaneEngine();
plane.hasFirstClass = true;
plane.hasBathroom = false;
plane.numberOfSeats = 100;
// etc.

In another place within this airline application, you need to write some code that does the same thing except makes the numberOfSeats variable a different value:

plane.numberOfSeats = 50;

Should we copy and paste all the code that creates a new airplane? Of course not!

Instead, we can create targeted functions that will deal with creating the airplane for us. These are called Factory Functions.

This will allow us to easily create a new airplane whenever we want and also gain the benefits of being able to configure how that plane is built:

const createPassengerPlane = (numberOfSeats: number): Airplane => {
    const plane = new Airplane();
    plane.type = PlaneType.Passenger;
    plane.engine = new...