dev-resources.site
for different kinds of informations.
The TypeScript Experience
A few days ago I read a thread on Twitter where the author asked "Why wouldn’t you use TypeScript?" to people that wouldn't use TypeScript.
Reading through the answers, the perceptions of TypeScript among people that wouldn't use it are that
- It is intimidating
- It is an overhead
- It makes it tedious to write code
- It makes it harder to read code
- It slows down development
- It doesn't protect from runtime errors
These seem not direct critiques of static typing in general, but rather a consequence of the specific unsound static type system implemented in TypeScript, that similarly to Flow, is based on structural subtyping. This means that TypeScript’s type system allows certain operations that can’t be known at compile-time to be safe, type inference might be not correct, and it requires some level of manually-written type annotations.
In contrast, other languages like Rust, Haskell, OCaml, Elm, and F# have a sound type systems, like the HMTS (Hindley–Milner Type System), that do not require type annotations, and the types are always inferred correctly. These type-systems make sure that the code will not generate type errors at runtime. Moreover, together with other design choices, like making errors explicit in the type system ("Maybe", "Either", etc.), languages that use sound type-system are able to detect other families of runtime errors at compile time.
This is a topic already discussed at length but I wonder if there are some new perspectives.
My questions
- Are these answers reflecting a significant reality or are they just the complaints of a small minority?
- If the unsatisfaction is relatively common, is it correlated to the TypeScript's unsoundness, as explained above or the unsoundness is not an issue after all?
- Can TypeScript be improved in this respect? Or, in broader terms, can a superset of JavaScript support a sound type system without becoming overly complicated?
- Or maybe a sound type system can only be achieved either by limiting JavaScript or with a different language that compiles to JavaScript?
Let me know what you think in the comment section below ❤️
Appendix - Curated overview of the Twitter thread
• Question
Looking to hear from folks who wouldn’t use TypeScript. Why wouldn’t you?
• Answers
đź’¬
In my day job, I have to use Typescript. In my projects, I refuse.
- Tedious writing types which 99% of the time are completely unnecessary, but required by the TypeScript compiler
- Does not catch bugs
- Reading code becomes much harder
- Still needs runtime checks
đź’¬
Because the type system is unsound and it seems to be way more complex and magical than what I would want from my type system.
đź’¬
I spoke to a few. Found 2 types:
- Just starting and intimidated by the wave of red
- Experienced enough to avoid the common JavaScript pitfalls and did not get the aha moment from TypeScript
đź’¬
Because TypeScript slows down the development of greenfield projects. It's a tool that benefits for a certain scale.
đź’¬
Part of it was that the flexibility of JavaScript is one of its core strengths so by removing the flexibility you're removing something good.
đź’¬
TypeScript is very useful and I find it invaluable in my day job, but it can be overkill for very small and one-off things. For other projects, there are other strongly typed compile-to-JS languages with more attractive type systems that are sometimes suitable.
đź’¬
I'm not sure if the overhead of TypeScript is enough to justify type issues in JavaScript. Maybe in huge projects.
đź’¬
I have tried it but had lots of problems with it. Also because some of my functions return values of different types depending on the situation. In the end, I don't get enough benefit from it. Type safety is nice to have, but I think I prefer the flexibility of JavaScript.
đź’¬
It's hard to use a bad type system when you've used good ones in the past.
đź’¬
I'm using it on my current project because stability is increasingly important, I wanted an excuse to learn a new thing and not get left behind, and I've been wrong before about new tools so I figured I'd give it a shot. But overall it's cost me more time than it's saved.
đź’¬
- Bloat (readability perhaps being the most important aspect of code)
- Need to safeguard stuff for the runtime regardless of whatever "guarantees" I’ve gotten ahead of that time
- Further from the metal
- More tooling to know and maintain
đź’¬
It slowdowns development time if you aren't used to it already. I've spent days working on things trying to type them while writing the code that could have been done in a single day.
đź’¬
From a huge supporter of TypeScript:
- Compile times can increase if not incremental builds or static type checking
- "Clever" devs abusing it
- No real guarantees, just assurances
- A lot more code to manage
- Some libraries have less than desirable type definitions
đź’¬
Heavy, a bit slower, and overkill for most projects. We spend a lot of time researching good libraries to avoid writing too much code by ourselves - then why use TypeScript and write all that (mostly unnecessary) code. And most importantly - doesn't catch all bugs (not even close)!
đź’¬
- Too much time spent pleasing the type system.
- Too many different configurations.
- I don't need to have a step before running JavaScript code on Node.js, why would I add one?
- No runtime-type checking
đź’¬
I’ve spent more time fighting missing/broken type definitions in 3rd party libs than I care to admit.
For this reason, I won’t ever choose TS again.
đź’¬
Cost to Benefit ratio is too high for some projects:
Benefit:
- It's good to know the type of function argument (Especially for libraries)
- Intellisense
- Knowing error before runtime
Cost:
- It's another skill to learn. TypeScript is huge
- It has flavors. I have seen Array or string[]
- TSConfig is another pain
- Types can be too complex, why can't it just be a mix of primitives
- The errors are overwhelming. I use eslint, it only warns
đź’¬
We wrote enough Java in our careers.
đź’¬
- The syntax can get verbose and unreadable
- Everything (build, test, IDE) is slower
- Not enough libraries come with types
- Sometimes spend an hour just to appease the type system
And that’s coming from someone (me) who is using TS on all their projects.
đź’¬
TypeScript has to sacrifice too much to stay JS compatible. JS does not give a good dev UX by modern standards and TS does not give you a step change improvement. Try Elm!
For more answers, check the original Twitter thread.
Header illustration derived from Like emoji vector created by rawpixel.com - www.freepik.com.
đź”´ Does any of these answers resonate with you and your experienceâť“
đź”´ Do you think there is something that can be done to change the TypeScript experience, especially when compared with languages that use a sound type systemâť“
Let me know in the comments section below
Featured ones: