Typescript - Tips & Tricks - Never type

March 17, 2021

Last updated: September 9, 2021

433 words

Post contents

Today I want to talk about the never type. As you can understand, this type identifies a piece of code that will never be executed or represents a state that shouldn’t exist. Here an example

const throwException: () => never = () => {    throw new Error();};throwException()console.log('never called');

In this simple example, you can see how the "throwException" method never permits the code execution of the console.log. In this case, the "throwException" method returns the never type because the method doesn't return any value but throws an error. To better understand the never type I show you another simple example

type Square = {    kind: "square";    size: number;};type Rectangle = {    kind: "rectangle";    with: number;    height: number;};type Circle = {    kind: "circle";    radius: number;};type Shape = Square | Rectangle | Circle;const area = (shape: Shape): number => {    if (shape.kind === "square") return shape.size * shape.size;    if (shape.kind === "rectangle") return shape.with * shape.height;    // if (shape.kind === "circle") return shape.radius * 2 * Math.PI;    const _exhaustiveCheck: never = shape; // Type 'Circle' is not assignable to type 'never'.    return _exhaustiveCheck;};

In this example, you can see how the "area" method detects the kind of the shape and it calculates the relative area. I leave the circle type comment voluntarily, so I can show you the power of the never type. At the end of the area method, you can see how the code assigns the shape to the field "_exhaustiveCheck" of type never. In this case, the typescript language detects that if you pass a circle shape at the area method, the line "const _exhaustiveCheck: never = shape;" will be executed, so it notifies you raising an error. The typescript language detects that the never type could be executed at runtime so it tries to prevent this problem. To fix this problem the previous method can be reviewed in this way

type Square = {    kind: "square";    size: number;};type Rectangle = {    kind: "rectangle";    with: number;    height: number;};type Circle = {    kind: "circle";    radius: number;};type Shape = Square | Rectangle | Circle;const area = (shape: Shape): number => {    if (shape.kind === "square") return shape.size * shape.size;    if (shape.kind === "rectangle") return shape.with * shape.height;    if (shape.kind === "circle") return shape.radius * 2 * Math.PI;    const _exhaustiveCheck: never = shape;    return _exhaustiveCheck;};

Now the code is compiled successfully and the never type is assigned correctly.

From the never type it's all. See you soon guys

Subscribe to our newsletter!

Subscribe to our newsletter to get updates on new content we create, events we have coming up, and more! We'll make sure not to spam you and provide good insights to the content we have.