Stefan Baumgartner

Lies we Tell Ourselves As Developers

How can 10 lines of valid TypeScript still be full of runtime errors? Discover the surprising gaps in its type system.

Lies we Tell Ourselves As Developers
#1about 2 minutes

The hidden dangers in everyday TypeScript code

A seemingly simple code snippet that passes type checks can still be riddled with runtime errors that TypeScript is supposed to prevent.

#2about 2 minutes

Why network requests returning `any` breaks type safety

The `any` type returned by default from I/O operations like `fetch` allows unsafe assignments, which can be mitigated by patching interfaces to return `unknown`.

#3about 2 minutes

Handling errors safely with the `unknown` type

Since anything can be thrown in JavaScript, catch block errors are typed as `any`, but using `unknown` and `instanceof` checks provides a safer way to handle them.

#4about 2 minutes

The disconnect between function overloads and implementation

Function overloads define a public API but do not enforce that the implementation correctly returns the specified types for each overload signature.

#5about 1 minute

Using conditional types to enforce return types

Conditional types can replace function overloads to create a more complex type signature that forces the developer to correctly handle different return paths.

#6about 3 minutes

How mutability breaks TypeScript's type tracking

TypeScript does not track type changes that occur from mutable operations like `array.push`, leading to a disconnect between the static type and the runtime value.

#7about 5 minutes

The trade-offs and lies within the solutions

Each proposed solution, from declaration merging to generics, introduces its own set of new problems and potential bugs.

#8about 3 minutes

Understanding TypeScript's core design philosophy

TypeScript intentionally prioritizes developer productivity over a provably sound type system, requiring developers to understand and manage these trade-offs.

#9about 3 minutes

The developer's role is to make conscious decisions

Software engineering is about making informed decisions and choosing the right tools and patterns for your team, rather than following dogmatic advice.

#10about 6 minutes

Q&A on Rust, `instanceof` alternatives, and `ts-reset`

The speaker answers audience questions about his favorite language (Rust), using Zod for runtime type checking instead of `instanceof`, and the trade-offs of using `ts-reset`.

Related jobs
Jobs that call for the skills explored in this talk.

Featured Partners

Related Articles

View all articles
DC
Daniel Cranney
Exploring TypeScript: Benefits for Large-Scale JavaScript Projects
JavaScript is the backbone of web development, powering everything from small websites to large-scale enterprise applications. However, as projects grow in complexity, maintaining JavaScript code can become increasingly difficult. This is where TypeS...
Exploring TypeScript: Benefits for Large-Scale JavaScript Projects
DC
Daniel Cranney
Dev Digest 195: End of Likes, JavaScript’s a Zoo, and Messing with Bots!
Inside last week’s Dev Digest 195 . 👎 No more external likes 🤗 Needy programs 📉 The worst selling Microsoft product 🟨 JavaScript engines zoo 🍞 No more toasts! 🤖 Messing with bots 👔 Beware of fake job interviews 🗞️ Join over 150,000 developers alread...
Dev Digest 195: End of Likes, JavaScript’s a Zoo, and Messing with Bots!
BR
Benjamin Ruschin
The HTML Elements That You’re Probably Over-Engineering
As frameworks have become more and more commonplace in the world of web development, so too has the over-engineering of features made possible by our humble old friend, HTML. The mental models that come with using state management in React, Vue and o...
The HTML Elements That You’re Probably Over-Engineering
DC
Daniel Cranney
How to Avoid Over-Engineering
In today’s software development world, the demand for designing applications that are both robust and easy to maintain is more pressing than ever. Many developers encounter the architectural chaos left behind in older codebases, leading to frustratio...
How to Avoid Over-Engineering

From learning to earning

Jobs that call for the skills explored in this talk.