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 1300+ tech skills courses.