In this article, we will learn how to create custom hooks in React. Primarily, Hooks are introduced to implement the functionalities of a Class component into a Functional component. Hooks are reusable functions.
Why do we need to use custom Hooks in React
Custom hooks enable us to remove unnecessary duplicated logic from our React components.
Reusability – The same code can be uses multiple times without writing it many times.
Maintainability – We have to change the logic of hooks only once.
It improves the readability of a React functional component.
Rules to write and implement a custom React hook
Custom hooks begin with keyword ‘use’. It is not necessary to begin the custom Hook name with the use keyword but I recommend you to write
custom Hooks starting with the use keyword because it enables us to spot the bug quickly.
Custom hooks always contain built-in React hooks or other custom hooks. If a custom hook does not contain any hook then it will not be a custom
hook.
We should call Hooks at the top level. We cannot use hooks inside nested functions, conditions and loops.
Now, let’s create our own custom React Hooks.
Firstly, I am going to create simple Counter Functional component in which our state value increase and decrease by 1 and initial value is set to 0.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
import { useState } from 'react' function Counter() { const [count, setCount] = useState(0); function Increment() { setCount(count + 1) } function Decrement() { setCount(count - 1) } return ( <div> <h1>{count}</h1> <button onClick={Increment}>Increment</button> <button onClick={Decrement}>Decrement</button> </div> ) } export default Counter; |
Output will be shown like this
Now, if we want to render above functionality in multiple component so here custom hook comes into the role. Basically we will modify the Counter component to make a hook named as ‘useCounter’. So after some modification code will look like this.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
import { useState } from 'react' function useCounter(initialValue=0) { const [count, setCount] = useState(initialValue); function Increment() { setCount(count + 1) } function Decrement() { setCount(count - 1) } return [count , Increment , Decrement] } export default useCounter; |
Let’s say, we want to use our custom hook ‘useCounter’ in three different component e.g. Counter1.jsx, Counter2.jsx, Counter3.jsx. So we will import in our components like this.
Counter1.jsx
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
import useCounter from './Counter' function Counter1() { const [count, Increment, Decrement] = useCounter(10) return ( <div> <h1>{count}</h1> <button onClick={Increment}>Increment</button> <button onClick={Decrement}>Decrement</button> </div> ) } export default Counter1 |
Counter2.jsx
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
import useCounter from './Counter' function Counter2() { const [count, Increment, Decrement] = useCounter(20) return ( <div> <h1>{count}</h1> <button onClick={Increment}>Increment</button> <button onClick={Decrement}>Decrement</button> </div> ) } export default Counter2 |
Counter3.jsx
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
import useCounter from './Counter' function Counter3() { const [count, Increment, Decrement] = useCounter(-10) return ( <div> <h1>{count}</h1> <button onClick={Increment}>Increment</button> <button onClick={Decrement}>Decrement</button> </div> ) } export default Counter; |
You can see that initial state value of every component is changed.
Now we have to import all these components in our App.js file to render it on the webpage.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
import './App.css'; import Counter1 from './Counter1'; import Counter2 from './Counter2'; import Counter3 from './Counter3'; function App() { return ( <div className="App"> <Counter1/> <Counter2/> <Counter3/> </div> ); } export default App; |
Output will be shown like this
Now you are able to create your own custom React hook.
CONCLUSION
I hope this blog help you in an effective way. Please give your valuable suggestions in the comment section below.
Thanks for reading.
Have a nice day !
Find More Blogs
Enhancing Productivity with Dynamics 365: The Power of Session Restore
Spread the love Enhancing Productivity with Dynamics 365:
Salesforce Admin
Spread the love In our last blog, we discussed common
Unlocking AI with Spring Boot: Real-World Use Cases and Solutions
Spread the love Artificial Intelligence (AI) has moved from
Enhancing Performance with Reactive Java: A Beginner-Friendly Guide
Spread the love In today’s fast-paced software
Integrating Azure Function with Dynamics 365
Spread the love Signup on azure portal and make sure to
How to Create a Power Apps Component Framework (PCF) with React
Spread the love If youʼve been looking to supercharge your
Customize lead qualification for a seamless experience
Spread the love When the 2024 Release Wave 2 was launched,
Create a Custom Console Command in Spryker
Spread the love In Spryker, developers can create custom
SALESFORCE
Spread the love Salesforce is a cloud-based software
CRUD Operation in Spryker Backoffice with a Custom Module
Spread the love Spryker is a highly flexible and modular
data:image/s3,"s3://crabby-images/e281e/e281eb203e38c6ebddae45036efd8093103f89b2" alt="bluethinkinc Blogs"
bluethinkinc_blog
2023-04-05