Type Annotation vs Type Assertion in TypeScript

In this latest blog from the developers on our Product Traction team, they outline the difference between Type Annotation and Type Assertion in TypeScript.

In the world of TypeScript, understanding the distinction between Type Annotation and Type Assertion can be crucial for writing clean, efficient, and error-free code. Let's delve into these concepts.

Type Annotation

Type Annotation is a method where we explicitly define the type of an object at the time of declaration. Consider the following example:

const var: someType = { some: 'value' };

Here, we're telling TypeScript directly that the variable 'var' is of 'someType'. The benefit of using this approach is that it provides a safer way of typing as it is done at the declaration. Consequently, if the variable mutates and deviates from the initially set type, TypeScript will warn us about it.

Type Assertion

On the other hand, Type Assertion is a bit different and used when TypeScript is unaware of the correct type. In this case, we are the ones informing TypeScript about the type. For instance, consider this example:

const var = { some: 'value' } as someType;

Here, we're asserting that the variable 'var' is of 'someType'. This method is particularly handy when dealing with situations where the exact type is known to us but not to TypeScript, such as responses from API requests.

Interestingly, with Type Assertion, the type doesn’t necessarily have to match. This flexibility makes it a good fit for testing scenarios. When testing, we usually don't care about the full structure of the object; rather, we're more interested in specific properties that we need.

Essentially, both Type Annotation and Type Assertion have their unique use-cases and can be leveraged as per the requirements of our application. The key is to understand when to use which, and hopefully, this post has helped clear that up!


The Thin Air Labs Product Traction team provides strategic product, design and development services for companies of all sizes, with a specific focus on team extensions where they seamlessly integrate into an existing team. Whether they are deployed as a team extension or as an independent unit, they always work with a Founder-First Mindset to ensure their clients receive the support they need.

To learn more about our Product Traction service, go here.

Build what's next with us