TS Router 설치
yarn add react-router-dom @types/react-router-dom
1. 파일 구조
data:image/s3,"s3://crabby-images/13c88/13c88f29057cd8f8d91cf1d5fb22461f949c86de" alt=""
2. modules/counter.ts 파일
- 뒤에 as const 를 붙여줌으로써 나중에 액션 객체를 만들게 action.type 의 값을 추론하는 과정에서
- action.type 이 string 으로 추론되지 않고 'counter/INCREASE' 와 같이 실제 문자열 값으로 추론 되도록 해준다.
data:image/s3,"s3://crabby-images/f4a2a/f4a2afebd995699011b4936de9555b53340c4cc4" alt=""
3.components/Counter.tsx 파일
data:image/s3,"s3://crabby-images/2e1a4/2e1a484dd271d9cf8c65dde77c965a64f3f720db" alt=""
4. containers/CounterContainer.tsx 파일
data:image/s3,"s3://crabby-images/52031/5203194817a6b7c2e913d633177b394fbd34e81a" alt=""
★ 5. modules/index.ts rootReducer 선언!
data:image/s3,"s3://crabby-images/fdfa4/fdfa486d10eafbeabe9f6c22352eac1f1a3b1d62" alt=""
6. App.tsx // CounterContainer 리턴
data:image/s3,"s3://crabby-images/710ed/710edc8bfe7bf35c78f081c265d778be55028ac0" alt=""
★ 7. index.tsx // store
data:image/s3,"s3://crabby-images/9e282/9e28231eaf652321aec6276d9a6592002d500de3" alt=""
실행 결과
data:image/s3,"s3://crabby-images/21b13/21b13614617e636096bdb1be41296ac099e8f5f0" alt=""