Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[React] Prop Drilling #112

Open
mahfujul-helios opened this issue Mar 30, 2024 · 0 comments
Open

[React] Prop Drilling #112

mahfujul-helios opened this issue Mar 30, 2024 · 0 comments

Comments

@mahfujul-helios
Copy link
Collaborator

Prop Drilling

What is Prop Drilling?

Prop drilling, also known as "threading props" or "component chaining," refers to the process of passing data from a parent component down to nested child components through props.

Prop drilling occurs when a prop needs to be passed through several layers of nested components to reach a deeply nested child component that actually needs the prop. Each intermediary component in the hierarchy has to pass the prop down, even if it doesn't use the prop itself.

Consider a scenario where you have a top-level component that fetches data from an API and needs to pass this data down to multiple nested child components.

Instead of directly passing the data to each child component, you pass it through each intermediary component in the hierarchy until it reaches the desired child component. This passing of props through multiple levels of components is what prop drilling entails.

Let's illustrate this with an example:

// ParentComponent.js
import React from 'react';
import ChildComponent from './ChildComponent';

function ParentComponent() {
  const data = 'Hello from Parent';

  return (
    <div>
      <ChildComponent data={data} />
    </div>
  );
}

export default ParentComponent;
// ChildComponent.js
import React from 'react';
import GrandchildComponent from './GrandchildComponent';

function ChildComponent(props) {
  return (
    <div>
      <GrandchildComponent data={props.data} />
    </div>
  );
}

export default ChildComponent;
// GrandchildComponent.js
import React from 'react';

function GrandchildComponent(props) {
  return <div>{props.data}</div>;
}

export default GrandchildComponent;

In this example, GrandchildComponent needs to access the data prop, but ParentComponent and ChildComponent do not use it. However, the data prop must still be passed through them.

Challenges of Prop Drilling

Complexity and Boilerplate Code

Prop drilling can lead to increased complexity and boilerplate code, especially in large component trees. As components get nested deeper, managing the flow of props becomes more challenging and can clutter the codebase.

// Example of Prop Drilling
const ParentComponent = () => {
    const data = fetchData(); // Assume fetching data from an API
    return (
        <ChildComponentA data={data} />
    );
};

const ChildComponentA = ({ data }) => {
    return (
        <ChildComponentB data={data} />
    );
};

const ChildComponentB = ({ data }) => {
    return (
        <ChildComponentC data={data} />
    );
};

// This continues...
@mahfujul-helios mahfujul-helios changed the title Prop Drilling [React] Prop Drilling Mar 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant