Get "PHP 8 in a Nuthshell" (Now with PHP 8.4)
Amit Merchant

Amit Merchant

A blog on PHP, JavaScript, and more

Type annotate arguments for subset of a given type in TypeScript

Often, there comes a scenario when you want to type annotate (or type hint) some of the variables or arguments for a subset of a given type.

For instance, let’s say, we have the following interface…

interface User {
    id: number;
    name: string;
    email: string;
}

And we want to type annotate one of the arguments of the following function using User, we can do it like so.

function updateDetail(user: User) {
    return {...user}
}

But let’s say, you want to add another argument which will be a subset of User type which only includes property email, how would do it? Well, there are utility types in TypeScript that come to rescue in such situations.

The Partial<Type> utility type

So, if we want to type annotate using the subset of User we can use Partial<User> as a type annotation, which will type check for any subset of User. So, if we want to add another argument in the previous function, we can do it like so.

function updateDetail(user: User, details: Partial<User>) {
    // logic to update user detail

    return {...user, ...details}
}

And this is how we can call it.

const user = {
    id: 1,
    name: 'Harry Potter',
    email: 'harry@hogwartz.com'
}

const details = {
    email: 'harrypotter@hogwartz.com'
}

const updateUser = updateDetail(user, details);

Notice, the detail object is the subset of user, so this won’t throw any type error as long as detail is the subset of user. But as soon as, detail is not a subset of user, let’s say,

const details = {
    username: 'harrypotter@hogwartz.com'
}

…it will throw the following error.

Type '{ username: string; }' has no properties 
in common with type 'Partial<User>'

Like this article?

Buy me a coffee

👋 Hi there! I'm Amit. I write articles about all things web development. You can become a sponsor on my blog to help me continue my writing journey and get your brand in front of thousands of eyes.

Comments?