React Hooks let us write pure functional components without ever using the class syntax. Usually, but not always, the less code we have to write, the faster we can build our application.
Step 1. Refactoring From a Class to a Functional Component
Take this React class-based component. Our first step to using Hooks would be to refactor it into a functional component. Remember, you can use Hooks only with functional components.
The component has hasError and planets state variables. When the component mounts, we call the Star Wars API and fetch the information.
Here’s how we would transform the component into a functional component.
Tada! A functional component with Hooks. There’s just one problem, though: Hooks don’t have lifecycle methods such as componentDidMount or componentWillMount.
Step 2. useEffect
The useEffect Hook lets you perform side effects in function components. Data fetching, setting up a subscription, and manually changing the DOM in React components are all examples of side effects.
useEffect is a React Hook that accepts a callback as its first argument. Inside the first argument, we perform all the effect-related tasks.
Import the useEffect from React, and replace componentWillMount with this Hook.
What does useEffect do?
By using this Hook, you tell React that your component needs to do something after rendering. React will remember the function you passed (we’ll refer to it as our “effect”) and call it later after performing the DOM updates.
But why is the state still our initial state {}? Because, there’s no this.setState({}) function inside functional components.
Step 3. Moving From this.setState({}) to Hooks
Notice how we put a function inside the callback. The function is named fetchData and does exactly as it’s named.
If this looks more complicated, I assure you it’s not. Just like how we wrote a function inside componentDidMount, we do the same in the useEffect Hook.
To illustrate how simple it actually is, let’s move the fetchData function out of the Hook entirely.
Note: If you want the useEffect to behave like the componentDidMount lifecycle event, pass an empty array as the second argument, like so:
Think of the second argument as the dependencies for that effect. If one of the dependencies has changed since the last time, the effect will run again.