Building Mapped Types and Utility Types

Learn how to use mapped types and utility types in this lesson.

We'll cover the following

In addition to limiting variables to a set of specific literal values and defining enums, TypeScript allows you to define types that are based on other types, kind of like super-powered generics. These are called mapped types. TypeScript also has a bunch of predefined mapped types that it calls utility types.

So, let’s say we have our existing type TicketData:

interface TicketData {
  id: number
  row: number
  number: number
  status: TicketStatus
}

And let’s say we have a data source that is unreliable, and we want to make all the fields optional for data coming from that source. We could create a new type:

interface OptionalTicketData {
  id?: number
  row?: number
  number?: number
  status?: TicketStatus
}

But that’s kind of verbose, and if the TicketData type changes, we also have to change the new type.

TypeScript lets us do this more generically:

type OptionalTicketData = [P in keyof TicketData]?: TicketData[P]

I don’t want to get wildly hung up on the syntax here, but basically, we have a variable P that iterates over each type (in keyof and then adds the optional signifier to each type ?). Essentially what we’re getting here is a new type where every key in the old type is optional. This is something kind of like a type declaration and kind of like a function declaration.

Mapped types with generic types

Somewhat more usefully, you can create a mapped type with a generic type rather than with a specific type:

type Partial<T> = { [P in keyof T]?: T[P] }
type OptionalTicketData = Partial<TicketData>

# or you can skip the declaration
const x: Partial<TicketData>

I think that you are unlikely to be creating these in your day to day life, but TypeScript defines a few of them, and I can see a few, like Readonly<T> (which makes all the properties of the type read only) or NonNullable<T> (which constructs a new type excluding null or undefined) or ReturnType<T> (which resolves to the return type of a functional type) being useful now and again.

Here’s the application we have so far:

Get hands-on with 1400+ tech skills courses.