>웹 프론트엔드 >JS 튜토리얼 >React에서 깊게 중첩된 하위 구성 요소의 상위 구성 요소 상태를 업데이트하는 방법은 무엇입니까?

React에서 깊게 중첩된 하위 구성 요소의 상위 구성 요소 상태를 업데이트하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-10 13:33:11883검색

How to Update Parent Component State from a Deeply Nested Child Component in React?

Redux 없이 React에서 하위 항목에서 상위 항목으로 상태 업데이트를 전파하는 방법

React의 단방향 데이터 흐름 모델은 상위 구성 요소를 업데이트하는 데 종종 어려움을 겪습니다. 그들의 후손으로부터 상태. 다음 구성 요소 구조가 존재하는 시나리오를 고려해 보겠습니다.

Component 1
    - Component 2
        - Component 4
            - Component 5
Component 3

구성 요소 3이 구성 요소 5의 상태를 기반으로 데이터를 표시하는 것이 목표입니다. props는 불변이므로 Component 5에서 Component 1로 상태를 전달하는 것은 불가능합니다.

대신 React는 콜백 함수를 사용하여 하위-상위 통신을 통해 솔루션을 제공합니다. 다음 코드 조각은 이를 달성하는 방법을 보여줍니다.

class Parent extends React.Component {
  constructor(props) {
    super(props);
    this.handler = this.handler.bind(this);
  }

  handler() {
    this.setState({
      someVar: 'some value'
    });
  }

  render() {
    return <Child handler={this.handler} />;
  }
}

class Child extends React.Component {
  render() {
    return <Button onClick={this.props.handler} />;
  }
}

이 예에서 부모는 콜백 함수 handler()를 props를 통해 자식 구성 요소에 전달합니다. 하위 항목이 이 함수를 호출하면 상위 구성 요소의 상태 업데이트가 트리거되어 상태 변경이 구성 요소 트리 위로 전파될 수 있습니다.

이 접근 방식은 즉각적인 문제를 해결하지만 구성 요소 구조를 재고해야 할 수도 있습니다. . 주어진 시나리오에서 구성 요소 5와 3은 직접적인 관계가 없는 것으로 보입니다. 이 문제를 완화하려면 두 구성 요소의 상태를 관리하고 props를 통해 전파하는 상위 수준 구성 요소 내에 래핑하는 것을 고려하세요. 이를 통해 더욱 모듈화되고 유지 관리가 용이한 솔루션이 가능해졌습니다.

위 내용은 React에서 깊게 중첩된 하위 구성 요소의 상위 구성 요소 상태를 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.