React의 props와 state는 무엇일까?

props

부모 컴포넌트가 자식 컴포넌트에 전달하는 데이터
props는 읽기 전용으로, 자식 컴포넌트는 수정할 수 없다.

function ChildComponent(props) {
  props.name = "New Name"; // 오류 발생 가능
  return <div>{props.name}</div>;
}

컴포넌트 간의 데이터 흐름을 예측 가능하게 만들고, 재사용성을 높여준다.


state

컴포넌트 내부에서 관리되는 데이터
state는 동적으로 변경될 수 있으며, 컴포넌트 렌더링에 영향을 미친다.
state를 변경하면 컴포넌트는 다시 렌더링되며, UI가 업데이트 된다.
주로 사용자 입력이나 네트워크 요청의 응답에 따라 변하는 데이터를 관리할 떄 사용된다.


props가 자식 컴포넌트에서 변하지 않는 이유는?

리액트의 단방향 데이터 흐름의 원칙 때문
읽기 전용이기 때문에, 부모 컴포넌트에서 전달된 값이 자식 컴포넌트 내에서 임의로 변경되지 않는다.
이로 인해 버그 발생 가능성을 줄이고 디버깅을 쉽게 할 수 있다.
props가 변경될 수 있다면, 자식 컴포넌트는 독립적으로 동작하지 않게되고, 재사용이 어려워질 수 있다.
불변으로 유지됨으로써 컴포넌트는 외부 입력에 의존할 뿐 내부적으로 변경하지 않아 재사용성이 높아지고, 코드의 캡슐화가 강화된다.


자식 컴포넌트에서 부모 컴포넌트로부터 받은 props를 변경해야 한다면?

자식 컴포넌트가 부모로부터 받은 props를 변경해야 한다면, 부모 컴포넌트에서 상태로 해당 데이터를 관리하고, 상태 변경 함수를 자식 컴포넌트로 전달하는 방식으로 구현해야 한다.
이러면 데이터는 여전히 단방향으로 흐르고, 상태는 부모 컴포넌트가 관리하므로 일광성을 유지할 수 있다.
이러한 기법을 상태 끌어 올리기 라고 한다.

Categories:

Updated:

Leave a comment