Higher-order components or HOC is the advanced method of reusing the component functionality logic. It simply takes the original component and returns the enhanced component.
Syntax:
const EnhancedComponent = higherOrderComponent(OriginalComponent);
Reason to use Higher-Order component:
- Easy to handle
- Get rid of copying the same logic in every component
- Makes code more readable
Creating React Application:
-
Step 1: Create a React application using the following command.
npx create-react-app foldername
-
Step 2: After creating your project folder i.e. foldername, move to it using the following command.
cd foldername
Project Structure:
Example 1: Let say, we need to reuse the same logic, like passing on the name to every component.
Name.js
import React from 'react'   const EnhancedComponent = (OriginalComponent) => {     class NewComponent extends React.Component {           // Logic here           render() {             // Pass the callable props to Original component             return <OriginalComponent name= "neveropen"  />         }     }     // Returns the new component     return NewComponent }   export default EnhancedComponent; |
App.js
import React from "react" ; import "./App.css" import EnhancedComponent from './Name'    class App extends React.Component {   render() {     // Call the props from originalComponent     return <h1>{ this .props.name}</h1>   } }    // Passed the originalcomponent export default EnhancedComponent(App); |
Output: Here, we pass the name as a prop with the value for calling out from different components.
Example 2: In this example let’s implement some logic. Let’s make a counter app. In HighOrder.js, we pass the handleclick and show props for calling the functionality of the component.
Project Structure:
HighOrder.js
import React from 'react'   const EnhancedComponent = (OriginalComponent) => {     class NewComponent extends React.Component {           constructor(props) {             super (props);             // Set initial count to be 0             this .state = { count: 0 };         }           handleClick = () => {             // Incrementing the count             this .setState({ count: this .state.count + 1 });         }           render() {               // passed a handleclick and count in the originalComponent             // as a props for calling and adding the functionality             return <OriginalComponent                 handleclick={ this .handleClick}                 show={ this .state.count} />         }     }     // Returns the new component     return NewComponent } // Export main Component export default EnhancedComponent |
App.js
import React from 'react' import "./App.css" // importing HighOrder file import EnhancedComponent from './HighOrder'    class App extends React.Component {   render() {     // Destructuring the props     const { show, handleclick } = this .props       // Calling out the props     return <button onClick={handleclick}>{show}     </button>   } }     export default EnhancedComponent(App); |
Output:
Reference:https://reactjs.org/docs/higher-order-components.html