Conditional Types and Chaining
Learn about TypeScript's conditional types for dynamic type definition in functions and how to use conditional type chaining to obtain specific types.
We'll cover the following
Conditional types in functions
We should be familiar with the concept of conditional expressions with the following format:
(conditional) ? ( true statement ) : ( false statement );
Here, we have a condition followed by a question mark (?
) and then either a true
expression or a false
expression, separated by a colon (:
).
We can use this syntax with types as well to form what is known as a conditional type:
type NumberOrString<T> = T extends number ? number : string;
Here, we have defined a type named NumberOrString
that uses the generic syntax to define a type named T
. The type of T
is set to the result of the conditional type statement to the right of the assignment operator (=
).
This conditional type statement checks whether the type of T
extends the type number
. If it does, it will return the number
type, and if not, it will return the string
type.
We can use this conditional type within a function as follows:
Get hands-on with 1300+ tech skills courses.