DEV Community

Cover image for Understanding TypeScript Utility Types: Pick and Omit
Ibrahim Bagalwa
Ibrahim Bagalwa

Posted on • Updated on

Understanding TypeScript Utility Types: Pick and Omit

TypeScript provides several utility types to facilitate common type transformations.

These good features make it easy to manipulate types, either by selecting specific properties or removing unwanted ones from objects.

In this article, we'll demystify TypeScript's utility types, focusing on Pick and Omit. Whether you're new to TypeScript or a pro, understanding these concepts will improve your coding skills.

These utility types make it easy to work with just the data you need and simplify object manipulation in TypeScript.

Pick

Allows you to create a new type by selecting specific properties from an existing type.

interface User {
  id: number;
  username: string;
  email: string;
  isAdmin: boolean;
  createdAt: Date;
}
Enter fullscreen mode Exit fullscreen mode

If, you want to create a new type that only contains the essential information for displaying a user's profile, like their username and email. You can use Pick to achieve this:

type UserProfil = Pick<User, "username" | "email">;

const user: UserProfil = {
  username: "Ibrahim Bagalwa",
  email: "ibrahim.bagalwa.dev@gmail.com",
};
Enter fullscreen mode Exit fullscreen mode

UserProfil is a new type created using Pick, which includes only the username and email properties from the original User interface.

It allows you to work with a more concise representation of a user's profile without including unnecessary details.

Omit

Allows you to create a new type by taking all the properties from an existing type (Type) and then removing specific properties represented by Keys.

It's the opposite of the Pick utility type.

interface UserSettings {
    darkMode: boolean;
    notifications:boolean;
    showEmail: string;
    language: string;
}
Enter fullscreen mode Exit fullscreen mode

If you want to create a new type that excludes sensitive settings, like the user's email visibility. You can use Omit to achieve this:

type PublicUserSettings = Omit<UserSettings, "showEmail">

const userSettings: PublicUserSettings = {
  darkMode: true,
  notifications: true,
  language: "en",
};
Enter fullscreen mode Exit fullscreen mode

PublicUserSettings is a new type created using Omit, which includes all the properties from the original UserSettings interface except showEmail.

It allows you to create a type that represents only the public settings, hiding sensitive data from being exposed.

Pick allows you to choose certain properties from an object, while Omit lets you remove specific properties. Both are useful for working with precise data in TypeScript.

Top comments (0)