data:image/s3,"s3://crabby-images/a333b/a333b8a50ccfbe02ba1419fc9d4c312f4931c586" alt="How to Force Rerender With Hooks in React"
How to Force Rerender With Hooks in React
You can force re-renders of your components in React with a custom hook that uses the built-in useState
hook:
The following hook should only be used in exceptional cases. Only re-render your component when state changes.
import React, { useState } from 'react'
// Create a custom useForceUpdate hook with useState
const useForceUpdate = () => useState()[1];
// Call it inside your component
const Hooks = () => {
const forceUpdate = useForceUpdate();
return (
<button onClick={forceUpdate}>
Update me
</button>
);
};
The example above is equivalent to the functionality of the forceUpdate
method in class-based components. This hook works in the following way:
- The
useState
hook β and any other hook for that matter β returns an array with two elements, a value (with the initial value being the one you pass to the hook function) and an updater function. - In the above example, we are instantly calling the updater function, which in this case is called with
undefined
, so it is the same as callingupdater(undefined)
.
If you would like to see it in action, give it a try on Codesandbox
data:image/s3,"s3://crabby-images/8f4bf/8f4bf7ac1f38e75f3159bf7edf6b1a4479443e58" alt="Try the hook on codesandbox"
data:image/s3,"s3://crabby-images/a333b/a333b8a50ccfbe02ba1419fc9d4c312f4931c586" alt="How to Force Rerender With Hooks in React"
If you are interested in reading more about React hooks, see more examples for custom hooks or just learn about the basics, make sure to check out the article below.
data:image/s3,"s3://crabby-images/7da6d/7da6d42cafddd3738844896672d0881af2162ace" alt="All You Need to Know About React Hooks"
data:image/s3,"s3://crabby-images/fd043/fd0435920f32fd4c2a4898f750b95761e30f839b" alt="Mentoring"
Rocket Launch Your Career
Speed up your learning progress with our mentorship program. Join as a mentee to unlock the full potential of Webtips and get a personalized learning experience by experts to master the following frontend technologies: