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

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

Linda Hamilton
풀어 주다: 2024-12-10 13:33:11
원래의
843명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿