props와 state는 다르다는것을 알고 상황에 알맞게 잘 사용을 해야한다. 두 객체는 모두 렌더링 결과물에 영향을 주는 정보를 갖고 있지만 두객체의 차이는 분명하다. props은 properties의 줄임말로 함수 매개변수처럼 컴포넌트에 전달되는 반면 state는 함수 내에 선언된 변수처럼 컴포넌트 안에서 관리가 된다.
프로젝트를 설계할때는 state가 최소화되도록 작성하는게 좋다. 중복으로 작성하면 UI의 상호작용에 혼란을 줄수 있다.
일단 state가 변경되면 컴포넌트는 렌더링을 다시 시도한다. 아래와 같은 앱을 만들때 어떤 값을 props으로 사용하고, 어떤 값을 state로 사용하는지 생각을 해보자
- 부동산의 목록
- 유저가 입력한 검색어
- 체크박스의 값
- 필터링 된 부동산 목록
데이터에 대해 아래의 세 가지 질문을 통해 결정이 가능하다.
- 부모로부터 props 을 통해 전달이 되는지?
- 시간이 지나도 변하지 않는지
- 컴포넌트 안의 다른 state나 props을 가지고 계산하는지
위 세가지에 해당되면 props 이다.
부동산의 목록은 props을 통해 전달되기 때문에 props이고, 검색어와 체크박스는 시간이 지남에 따라 변하기 때문에 state의 값으로 상태값을 업데이트 해야 한다. 필터링 된 제품의 목록은 컴포넌트 안의 검색어, 체크박스의 값으로 계산하기 때문에 props이다.
'Web 개발 > React' 카테고리의 다른 글
[React] 절대경로로 모듈 import 하는 방법 (0) | 2020.02.04 |
---|---|
[React] Context를 사용해야 하는 이유와 사례 ( vs props) (0) | 2020.02.02 |
[React] 한 페이지에 여러 컴포넌트 삽입 하는 방법 (합성) (0) | 2020.02.02 |
[React] 상태값 Const 로 설정하는 방법 (0) | 2020.02.02 |
[React] 폼(Form) Input, Select, TextArea, Checkbox Example 코드 (0) | 2020.02.02 |