Learning React - Exercise control over your component state with Typescript
The last post left us with a bit of a problem.
Although our user component retrieves and displays data from ASP.NET API, it also flashes up some hard-coded data before the real data shows up.
It seems like we could just remove the hard-coded data so let’s try that…
Seems reasonable, except for one problem, it doesn’t compile.
Yes that’s right, javascript gets compiled these days! And in this case we run into an error.
This seems odd at first, it was working before.
Turns out, when we had our hard-coded data, Typescript was able to infer the type from the structure of this data.
So, because that data included an id property, everything “just worked”.
Now we don’t have any data, there’s nothing for the compiler to go off, so it blows up when it comes to this line…
Turns out, this isn’t a problem if we stop being lazy and actually define types for our state.
Then we can declare our component state’s type…
And finally, tweak the code where we set the initial state (to indicate the type).
Now everything compiles, plus we have the benefit that we’ve removed the ambiguity about our state.
You’ll get proper intellisense in Visual Studio Code and there’s less uncertainty all round!
Legacy .NET web apps causing you grief?
Build modern, reliable web applications, faster with .NET and Blazor.
Build better .NET web appsLoading…#
This has removed our flash of data, but what if we want to show a loading indicator when the data’s being retrieved?
We need a way to render different content if we’re loading data, then show the list once the data’s available.
As with all things in React, if we can change the underlying state as we’re making the API call, the user interface can react to that and show a loading indicator of some kind.
We can add a loading
boolean to IState.
Set it to false for starters.
Then flip this flag when we’re loading data from the back-end.
And finally make our html react to this and render some kind of loading indicator (when state.loading
is true).
This looks a bit weird the first time you see it so let’s break it down.
This will show the Loading div if this.state.loading
evaluates to true.
As a C# developer you’ll be used to the more classic if
statement.
So what is this &&
madness?!
Turns out, in javascript, the &&
logical operator returns the value of one of the specified operands.
If you have an expression like this.
The result would be ‘It’s Sunday’.
And this would return false!
The table over here explains this much better than I’d hope to!
So in the end, this is just a concise way of saying “show the loading indicator if this.state.loading
is true”.
Your state is typed!#
Whilst it’s tempting to throw any
around all over the place to avoid declaring types, this shortcut ultimately makes some things more difficult and removes the benefits of using Typescript in the first place.
Create your types, use conditional rendering and your components will react in a predictable way, based purely on the underlying state of the component.
All posts in Learning to use React with ASP.NET Core Web API
- Diary Of A Net Developer - Learning React
- Learning React - Building up the user interface using components and dummy data
- Learning React - How to connect React components to your ASP.NET Core Web API
- Learning React - Exercise control over your component state with Typescript
- Cross-Origin Request Blocked