As a developer working across both C# and TypeScript, I often find myself wanting familiar patterns from one language in the other. One concept that many C# developers miss when moving to TypeScript is the ability to declare a type as nullable, similar to how you’d handle nullable types in C# like int?
.
Thank me by sharing on Twitter 🙏
In C#, marking a value type as nullable is straightforward with the ?
syntax. When I started working more heavily in TypeScript, I wanted a similar way to handle nullability. Thankfully, there’s a clean and expressive way to do this, and I’ve shared this approach in a popular Stack Overflow answer to the question titled “How to declare a type as nullable in TypeScript?”.
To bring this C#-like behavior into your TypeScript projects, you can define a Nullable<T>
type like this:
type Nullable<T> = T | null;
interface Employee {
id: number;
name: string;
salary: Nullable<number>;
}
The Nullable<T>
type is a flexible solution that allows any type to be nullable, just like in C#. In the example above, the salary
property can either be a number
or null
, resembling C#’s int?
.
This pattern is not only clean but also intuitive, especially for developers coming from a C# background. It’s a simple way to bring a bit of the C# feel into your TypeScript projects while maintaining clear and maintainable code.
HP 910XL Black High-yield Ink Cartridge for HP Printers | Works with Printer Series: OfficeJet 8010, 8020; OfficeJet Pro 8020, 8030 | Eligible for Instant Ink | 3YL65AN
$52.89 (as of July 7, 2025 21:35 GMT +00:00 - More infoProduct prices and availability are accurate as of the date/time indicated and are subject to change. Any price and availability information displayed on [relevant Amazon Site(s), as applicable] at the time of purchase will apply to the purchase of this product.)Car Carplay Cable for iPhone 15/16e/16 Pro Max/Plus Cable, 2Pack USB A to USB C for CarPlay USBC Cord, iPad Pro/Air, Samsung, Pixel, Android Accessories Charging Wire Type-C Car Charger Cord 3FT White
$7.99 (as of July 7, 2025 21:35 GMT +00:00 - More infoProduct prices and availability are accurate as of the date/time indicated and are subject to change. Any price and availability information displayed on [relevant Amazon Site(s), as applicable] at the time of purchase will apply to the purchase of this product.)The AI-Driven Leader: Harnessing AI to Make Faster, Smarter Decisions
$17.05 (as of July 6, 2025 16:19 GMT +00:00 - More infoProduct prices and availability are accurate as of the date/time indicated and are subject to change. Any price and availability information displayed on [relevant Amazon Site(s), as applicable] at the time of purchase will apply to the purchase of this product.)This post ties back to the Stack Overflow answer where I first introduced this idea, and it’s become a popular reference for those looking to make their TypeScript code more expressive when handling nullability.