Dealing with Strictness
Learn to handle TypeScript strictness
We'll cover the following
Current errors
Compiling the file, I get a few errors:
- The
venue-display
file that is kicking off the call to React is not handling a potential undefined value. - Turbolinks can only be default-imported using the
allowSyntheticDefaultImports
. - The
dispatch
call to redux-thunk includes a type error that I don’t understand yet.
This is fewer than I was expecting, honestly. You can get more errors with other strict options, but they don’t seem tremendously useful to me to talk about.
Fixes
I’m going to fix the Turbolinks issue by adding the line "allowSyntheticDefaultImports": true,
to the tsconfig.json
file. This allows us to import modules that don’t have a default export, and doesn’t seem to have a whole lot of impact on us one way or another. Honestly, getting rid of Turbolinks would probably be fine as well.
Our venue_display
file has basically the same issue four times over: we have code like element.dataset["rows"]
, which is now technically of type string | undefined
, meaning the union type of a string or undefined, and we are passing it through to arguments that expect strings.
What we need to do is allow for the possibility that the values are undefined
by creating default values. This is a little slapdash, but it works fine for our purposes:
Get hands-on with 1300+ tech skills courses.