Creating strongly-typed class state
In this lesson, we are going to learn how to create a strongly-typed state in a class component.
We'll cover the following
Component without state type specified
We are going to use an exercise in CodeSandbox to work on a Counter
component. The task will be similar to what we did for the function-based Counter
component earlier in this course.
Click the link below to open the exercise in CodeSandbox:
We are going to add the current count as a state to the Counter
component. We’ll start by initializing the count
state:
class Counter extends React.Component {
state = {
count: 0
}
render() {
return <button>Click to start counter</button>;
}
}
Alternatively, we could initialize the count
state in a constructor as follows:
class Counter extends React.Component {
constructor(props: {}) {
super(props);
this.state = {
count: 0
};
}
render() {
return <button>Click to start counter</button>;
}
}
It’s up to you which state initialization approach you use - the TypeScript typing works well with both approaches.
Let’s also increment the count
when the button is clicked and output the count in the button:
render() {
return (
<button onClick={() => this.setState((state) => ({count: state.count + 1}))}>
{this.state.count ? this.state.count : "Click to start counter"}
</button>
);
}
The component does function as we want, but we have type errors where the count
state is referenced:
Get hands-on with 1300+ tech skills courses.