상태관리를 redux-thunk를 통해 store에서 Data를 가공 후 관리하도록 변경해 보았다.
💡해당 포스트에서는 벨로퍼트님의 redux 사용법을 토대로 코드를 작성했습니다.
action
data:image/s3,"s3://crabby-images/299a6/299a6da87db44ffbfd609bd2d38b37801b85c555" alt=""
- FILTER_DATA type을 정의했다.
- filterData라는 이름으로 action 함수를 정의했다.
Thunk
✨오늘의 주인공! Thunk 함수✨
1. 기능함수 구현
data:image/s3,"s3://crabby-images/6bace/6bacebe170dcd7f9ced50be2bebe7f9f00706626" alt=""
2. thunk함수 구현
data:image/s3,"s3://crabby-images/a533e/a533e13b12c373e8d6490b3e0d54501869a3a822" alt=""
filter함수에서 reducer의 상태값이 필요한 구성입니다.
- parameter로 dispatch와 getState를 가진 함수를 리턴하는 함수를 작성!
- 따라서 payload, data라는 이름의 상태값을 쓰기 위해 변수 지정을 했다.
- 해당 함수에서 data, payload의 데이터를 통해 filter, countData 통해 변환된 데이터 값을 반환하도록 설정
- 마지막으로 filterData 액션함수의 parameter로 결과값을 담아준다.
reducer
data:image/s3,"s3://crabby-images/a8928/a8928c7fde4e15dbba232db5724170ad6aca298b" alt=""
- 연관이 있는 액션들을 관리하기에 같은 리듀서 내부에서 switch문을 통해 관리가 진행되고 있는 모습이다.
store
data:image/s3,"s3://crabby-images/491db/491dbf1a79c5de85898b0303d8fb173342a89e44" alt=""
- store부분에서 thunk를 import 한다.
- store를 생성하는 parameter에 applyMiddleware(thunk) 형태로 thunk를 추가해준다!
본 프로젝트에는 thunk 외에 saga를 추가로 사용할 예정이다.
따라서 middlewares라는 변수 내부에 사용할 미들웨어들을 묶음으로 지정하여 binding을 했다.
use
data:image/s3,"s3://crabby-images/afad1/afad143b1e834465bf157adc3e59c924c7700076" alt=""
- 컴포넌트에서 thunk 함수인 filterdData를 import!
data:image/s3,"s3://crabby-images/72e67/72e6720ac7d6d93d321150987e251a5150dc3c2c" alt=""
- useEffect를 통해 payload의 값이 바뀌면 thunk함수인 filtedData가 디스패치되도록 설정!
result
#console.log
data:image/s3,"s3://crabby-images/f4608/f460828ce1fc37f66bbebf0852ef5e4238bf6fa8" alt=""
#부모 component
data:image/s3,"s3://crabby-images/bb602/bb602e8207f7ba530e46caf63b375a8aac6980b0" alt=""
- 부모 컴포넌트에서 아무런 props를 전달하지 않는 모습
#WordCloud component
data:image/s3,"s3://crabby-images/aea4e/aea4e4570abe9bb2aa243dc4b152d342898eddac" alt=""
data:image/s3,"s3://crabby-images/21336/213367ba6e4f406b7fe2cda3b4ad4753716cbb5f" alt=""
- 컴포넌트 내부에서 바로 스토어에 접근해 상태값을 사용하는 모습을 볼 수 있다!
#Chart component
data:image/s3,"s3://crabby-images/9d0c0/9d0c05c6f8da71be2ca53986beb143807ae3ce6a" alt=""
data:image/s3,"s3://crabby-images/83c9e/83c9e1fbe45c8849d0125c1e2f73c103c799b4ce" alt=""
- 컴포넌트 내부에서 바로 스토어에 접근해 상태값을 사용하는 모습을 볼 수 있다!