Reactician

Write reusable logic with custom React Hooks

Hooks are a relatively new concept in React, but they already solve a problem that is quite common in large React applications. Building performant, stateful interfaces in a reusable way is hard.

While React Contexts solve the problem of consuming and mutating state over numerous components without passing props along the tree, hooks solve the problem of writing stateful logic that is reusable.

Reusing logic without hooks

A common approach to reuse stateful logic is writing higher-order components (HOC) or by passing render props. HOC's require you to wrap your Components that share the logic into wrappers and render props require you to rewrite your render logic to handle the injections. This is fine in small and isolated components, but if you're managing global state that needs to be consumed and mutated all over your application, you create a lot of coupling around render logic.

By using Contexts you might have already noticed the hook, which give access to state in the nearest parent , without writing a lot of boilerplate code per component.

Extracting logic from components

Lets say we have component where you can toggle between dark and light mode, like on this site. We need to track state changes for the toggle, but we would also like to store the user's preference in .

We can start writing our initial component to handle tracking the state. We also need some code to load the user's preference from and save the state to after the user toggles.


This component works fine, but most of the boilerplate for storing the user's preferences is tightly coupled to the component. Imagine we also need a component, which also stores the preferences in .

To reuse the functionality, we can extract the logic into it's own hook. If we need the same stateful logic in multiple components, we can just use the hook. If there's a bug in your logic, you'll only have to fix the hook, instead of multiple components.


By exposing the logic as the hook with the and arguments, we can easily reuse stateful logic in multiple components. Instead of writing code for storing user preferences into multiple components, we can reuse the logic in other components with minimal effort.

Lets refactor our component to use the new hook.


Creating new components that reuse the same stateful logic requires minimal effort. Now lets create the component we mentioned earlier.


Custom hooks are an effective way to write reusable stateful logic in a way that allows you to keep your components focussed on render logic.

By following this practice your code is less verbose, better readable and has a clear separation of concerns.

Stephan Lagerwaard
Stephan Lagerwaard
Frontend Engineer at Fiberplane.