Documentation - Utility Types (original) (raw)
TypeScript provides several utility types to facilitate common type transformations. These utilities are available globally.
Awaited<Type>
Released:4.5
This type is meant to model operations like await in async functions, or the.then() method on Promises - specifically, the way that they recursively unwrap Promises.
Example
ts
`type A = Awaited<Promise>;
type A = stringtype B = Awaited<Promise<Promise>>;
type B = numbertype C = Awaited<boolean | Promise>;
type C = number | boolean`Try
Partial<Type>
Released:
2.1
Constructs a type with all properties of Type set to optional. This utility will return a type that represents all subsets of a given type.
Example
ts
`interface Todo {
title: string;
description: string;
}
function updateTodo(todo: Todo, fieldsToUpdate: Partial) {
return { ...todo, ...fieldsToUpdate };
}
const todo1 = {
title: "organize desk",
description: "clear clutter",
};
const todo2 = updateTodo(todo1, {
description: "throw out trash",
});
`Try
Required<Type>
Released:
2.8
Constructs a type consisting of all properties of Type set to required. The opposite of Partial.
Example
ts
`interface Props {
a?: number;
b?: string;
}
const obj: Props = { a: 5 };
const obj2: Required = { a: 5 };
Property 'b' is missing in type '{ a: number; }' but required in type 'Required'.2741Property 'b' is missing in type '{ a: number; }' but required in type 'Required'.`Try
Readonly<Type>
Released:
2.1
Constructs a type with all properties of Type set to readonly, meaning the properties of the constructed type cannot be reassigned.
Example
ts
`interface Todo {
title: string;
}
const todo: Readonly = {
title: "Delete inactive users",
};
todo.title = "Hello";
Cannot assign to 'title' because it is a read-only property.2540Cannot assign to 'title' because it is a read-only property.`Try
This utility is useful for representing assignment expressions that will fail at runtime (i.e. when attempting to reassign properties of a frozen object).
Object.freeze
ts
`function freeze(obj: Type): Readonly;
`
Record<Keys, Type>
Released:
2.1
Constructs an object type whose property keys are Keys and whose property values are Type. This utility can be used to map the properties of a type to another type.
Example
ts
`type CatName = "miffy" | "boris" | "mordred";
interface CatInfo {
age: number;
breed: string;
}
const cats: Record<CatName, CatInfo> = {
miffy: { age: 10, breed: "Persian" },
boris: { age: 5, breed: "Maine Coon" },
mordred: { age: 16, breed: "British Shorthair" },
};
cats.boris;
const cats: Record<CatName, CatInfo>
`Try
Pick<Type, Keys>
Released:
2.1
Constructs a type by picking the set of properties Keys (string literal or union of string literals) from Type.
Example
ts
`interface Todo {
title: string;
description: string;
completed: boolean;
}
type TodoPreview = Pick<Todo, "title" | "completed">;
const todo: TodoPreview = {
title: "Clean room",
completed: false,
};
todo;
const todo: TodoPreview
`Try
Omit<Type, Keys>
Released:
3.5
Constructs a type by picking all properties from Type and then removing Keys (string literal or union of string literals). The opposite of Pick.
Example
ts
`interface Todo {
title: string;
description: string;
completed: boolean;
createdAt: number;
}
type TodoPreview = Omit<Todo, "description">;
const todo: TodoPreview = {
title: "Clean room",
completed: false,
createdAt: 1615544252770,
};
todo;
const todo: TodoPreview
type TodoInfo = Omit<Todo, "completed" | "createdAt">;
const todoInfo: TodoInfo = {
title: "Pick up kids",
description: "Kindergarten closes at 5pm",
};
todoInfo;
const todoInfo: TodoInfo
`Try
Exclude<UnionType, ExcludedMembers>
Released:
2.8
Constructs a type by excluding from UnionType all union members that are assignable to ExcludedMembers.
Example
ts
`type T0 = Exclude<"a" | "b" | "c", "a">;
type T0 = "b" | "c"type T1 = Exclude<"a" | "b" | "c", "a" | "b">;
type T1 = "c"type T2 = Exclude<string | number | (() => void), Function>;
type T2 = string | numbertype Shape =
| { kind: "circle"; radius: number }
| { kind: "square"; x: number }
| { kind: "triangle"; x: number; y: number };
type T3 = Exclude<Shape, { kind: "circle" }>
type T3 = {
kind: "square";
x: number;} | { kind: "triangle"; x: number; y: number; }
`Try
Released:
2.8
Constructs a type by extracting from Type all union members that are assignable to Union.
Example
ts
`type T0 = Extract<"a" | "b" | "c", "a" | "f">;
type T0 = "a"type T1 = Extract<string | number | (() => void), Function>;
type T1 = () => voidtype Shape =
| { kind: "circle"; radius: number }
| { kind: "square"; x: number }
| { kind: "triangle"; x: number; y: number };
type T2 = Extract<Shape, { kind: "circle" }>
type T2 = {
kind: "circle";
radius: number;}
`Try
NonNullable<Type>
Released:
2.8
Constructs a type by excluding null and undefined from Type.
Example
ts
`type T0 = NonNullable<string | number | undefined>;
type T0 = string | numbertype T1 = NonNullable<string[] | null | undefined>;
type T1 = string[]`Try
Parameters<Type>
Released:
3.1
Constructs a tuple type from the types used in the parameters of a function type Type.
For overloaded functions, this will be the parameters of the last signature; see Inferring Within Conditional Types.
Example
ts
`declare function f1(arg: { a: number; b: string }): void;
type T0 = Parameters<() => string>;
type T0 = []type T1 = Parameters<(s: string) => void>;
type T1 = [s: string]type T2 = Parameters<(arg: T) => T>;
type T2 = [arg: unknown]type T3 = Parameters;
type T3 = [arg: {
a: number;
b: string;}]
type T4 = Parameters;
type T4 = unknown[]type T5 = Parameters;
type T5 = nevertype T6 = Parameters;
Type 'string' does not satisfy the constraint '(...args: any) => any'.2344Type 'string' does not satisfy the constraint '(...args: any) => any'.
type T6 = nevertype T7 = Parameters;
Type 'Function' does not satisfy the constraint '(...args: any) => any'. Type 'Function' provides no match for the signature '(...args: any): any'.2344Type 'Function' does not satisfy the constraint '(...args: any) => any'. Type 'Function' provides no match for the signature '(...args: any): any'.
type T7 = never`Try
ConstructorParameters<Type>
Released:
3.1
Constructs a tuple or array type from the types of a constructor function type. It produces a tuple type with all the parameter types (or the type never if Type is not a function).
Example
ts
`type T0 = ConstructorParameters;
type T0 = [message?: string]type T1 = ConstructorParameters;
type T1 = string[]type T2 = ConstructorParameters;
type T2 = [pattern: string | RegExp, flags?: string]class C {
constructor(a: number, b: string) {}
}
type T3 = ConstructorParameters;
type T3 = [a: number, b: string]type T4 = ConstructorParameters;
type T4 = unknown[]type T5 = ConstructorParameters;
Type 'Function' does not satisfy the constraint 'abstract new (...args: any) => any'. Type 'Function' provides no match for the signature 'new (...args: any): any'.2344Type 'Function' does not satisfy the constraint 'abstract new (...args: any) => any'. Type 'Function' provides no match for the signature 'new (...args: any): any'.
type T5 = never`Try
ReturnType<Type>
Released:
2.8
Constructs a type consisting of the return type of function Type.
For overloaded functions, this will be the return type of the last signature; see Inferring Within Conditional Types.
Example
ts
`declare function f1(): { a: number; b: string };
type T0 = ReturnType<() => string>;
type T0 = stringtype T1 = ReturnType<(s: string) => void>;
type T1 = voidtype T2 = ReturnType<() => T>;
type T2 = unknowntype T3 = ReturnType<<T extends U, U extends number[]>() => T>;
type T3 = number[]type T4 = ReturnType;
type T4 = {
a: number;
b: string;}
type T5 = ReturnType;
type T5 = anytype T6 = ReturnType;
type T6 = nevertype T7 = ReturnType;
Type 'string' does not satisfy the constraint '(...args: any) => any'.2344Type 'string' does not satisfy the constraint '(...args: any) => any'.
type T7 = anytype T8 = ReturnType;
Type 'Function' does not satisfy the constraint '(...args: any) => any'. Type 'Function' provides no match for the signature '(...args: any): any'.2344Type 'Function' does not satisfy the constraint '(...args: any) => any'. Type 'Function' provides no match for the signature '(...args: any): any'.
type T8 = any`Try
InstanceType<Type>
Released:
2.8
Constructs a type consisting of the instance type of a constructor function in Type.
Example
ts
`class C {
x = 0;
y = 0;
}
type T0 = InstanceType;
type T0 = Ctype T1 = InstanceType;
type T1 = anytype T2 = InstanceType;
type T2 = nevertype T3 = InstanceType;
Type 'string' does not satisfy the constraint 'abstract new (...args: any) => any'.2344Type 'string' does not satisfy the constraint 'abstract new (...args: any) => any'.
type T3 = anytype T4 = InstanceType;
Type 'Function' does not satisfy the constraint 'abstract new (...args: any) => any'. Type 'Function' provides no match for the signature 'new (...args: any): any'.2344Type 'Function' does not satisfy the constraint 'abstract new (...args: any) => any'. Type 'Function' provides no match for the signature 'new (...args: any): any'.
type T4 = any`Try
NoInfer<Type>
Released:
5.4
Blocks inferences to the contained type. Other than blocking inferences, NoInfer<Type> is identical to Type.
Example
ts
`function createStreetLight(
colors: C[],
defaultColor?: NoInfer,
) {
// ...
}
createStreetLight(["red", "yellow", "green"], "red"); // OK
createStreetLight(["red", "yellow", "green"], "blue"); // Error
`
ThisParameterType<Type>
Released:
3.3
Extracts the type of the this parameter for a function type, or unknown if the function type has no this parameter.
Example
ts
`function toHex(this: Number) {
return this.toString(16);
}
function numberToString(n: ThisParameterType) {
return toHex.apply(n);
}
`Try
OmitThisParameter<Type>
Released:
3.3
Removes the this parameter from Type. If Type has no explicitly declared this parameter, the result is simply Type. Otherwise, a new function type with no this parameter is created from Type. Generics are erased and only the last overload signature is propagated into the new function type.
Example
ts
`function toHex(this: Number) {
return this.toString(16);
}
const fiveToHex: OmitThisParameter = toHex.bind(5);
console.log(fiveToHex());
`Try
ThisType<Type>
Released:
2.3
This utility does not return a transformed type. Instead, it serves as a marker for a contextual this type. Note that the noImplicitThis flag must be enabled to use this utility.
Example
ts
`type ObjectDescriptor<D, M> = {
data?: D;
methods?: M & ThisType<D & M>; // Type of 'this' in methods is D & M
};
function makeObject<D, M>(desc: ObjectDescriptor<D, M>): D & M {
let data: object = desc.data || {};
let methods: object = desc.methods || {};
return { ...data, ...methods } as D & M;
}
let obj = makeObject({
data: { x: 0, y: 0 },
methods: {
moveBy(dx: number, dy: number) {
this.x += dx; // Strongly typed this
this.y += dy; // Strongly typed this
},},
});
obj.x = 10;
obj.y = 20;
obj.moveBy(5, 5);
`Try
In the example above, the methods object in the argument to makeObject has a contextual type that includes ThisType<D & M> and therefore the type of this in methods within the methods object is { x: number, y: number } & { moveBy(dx: number, dy: number): void }. Notice how the type of the methods property simultaneously is an inference target and a source for the this type in methods.
The ThisType<T> marker interface is simply an empty interface declared in lib.d.ts. Beyond being recognized in the contextual type of an object literal, the interface acts like any empty interface.
Intrinsic String Manipulation Types
Uppercase<StringType>
Lowercase<StringType>
Capitalize<StringType>
Uncapitalize<StringType>
To help with string manipulation around template string literals, TypeScript includes a set of types which can be used in string manipulation within the type system. You can find those in the Template Literal Types documentation.