티스토리 뷰
state의 상태변화 로직이 복잡해질 경우 컴포넌트가 무거워짐,
이는 좋은 현상이 아니기 때문에 로직을 바깥으로 분리하여 관리하기 위해서, useReducer를 사용하는 것이 좋음
useReducer
useReducer 예시
const [count,dispatch] = useReducer(reducer,1)
//count: state와 동일 dispatch: 상태를 변화하는 action을 발생시키는 함수
//reducer : 일어난 상태변화를 처리 1 : count state의 초기값
실제 코드 적용 예시
useState -> useReducer 사용
import "./App.css";
import DiaryEditor from "./DiaryEditor";
import DiaryList from "./DiaryList";
import { useCallback, useMemo, useEffect, useRef, useReducer } from "react";
const reducer = (state, action) => {
switch (action.type) {
case "INIT": {
return action.data;
}
case "CREATE": {
const created_data = new Date().getTime();
const newItem = {
...action.data,
created_data,
};
return [newItem, ...state];
}
case "REMOVE": {
return state.filter((it) => it.id !== action.targetId);
}
case "EDIT": {
return state.map((it) =>
it.id === action.targetId ? { ...it, content: action.newContent } : it
);
}
default:
return state;
}
};
function App() {
//const [data, setData] = useState([]);
const [data, dispatch] = useReducer(reducer, []);
const dataId = useRef(0);
//API를 이용하여 글을 받아오는 함수
const getData = async () => {
const res = await fetch(
"https://jsonplaceholder.typicode.com/comments"
).then((res) => res.json());
//console.log(res);
const initData = res.slice(0, 20).map((it) => {
return {
author: it.email,
content: it.body,
emotion: Math.floor(Math.random() * 5) + 1,
created_data: new Date().getTime(),
id: dataId.current++,
};
});
dispatch({ type: "INIT", data: initData });
};
useEffect(() => {
getData();
}, []);
const onCreate = useCallback((author, content, emotion) => {
dispatch({
type: "CREATE",
data: { author, content, emotion, id: dataId.current },
});
dataId.current += 1;
}, []);
const onRemove = useCallback((targetId) => {
dispatch({ type: "REMOVE", targetId });
}, []);
const onEdit = useCallback((targetId, newContent) => {
dispatch({ type: "EDIT", targetId, newContent });
}, []);
//일기분석 기능
const getDiaryAnalysis = useMemo(() => {
const goodCount = data.filter((it) => it.emotion >= 3).length;
const badCount = data.length - goodCount;
const goodRatio = (goodCount / data.length) * 100;
return { goodCount, badCount, goodRatio };
}, [data.length]);
const { goodCount, badCount, goodRatio } = getDiaryAnalysis;
return (
<div className="App">
<DiaryEditor onCreate={onCreate}></DiaryEditor>
<div>전체 일기 : {data.length}</div>
<div>기분 좋은 일기 개수 : {goodCount}</div>
<div>기분 나쁜 일기 개수 : {badCount}</div>
<div>기분 좋은 일기 비율 : {goodRatio}</div>
<DiaryList
onEdit={onEdit}
onRemove={onRemove}
diaryList={data}
></DiaryList>
</div>
);
}
export default App;
'프로젝트 > 일기장' 카테고리의 다른 글
감정 일기장 - 페이지 추가적인 기능 구현 (0) | 2023.02.24 |
---|---|
감정 일기장 -페이지 생성 및 라우팅 구현 (0) | 2023.02.24 |
useContext (0) | 2023.02.22 |
useCallback (0) | 2023.02.22 |
React.memo (0) | 2023.02.21 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- dictionary
- 인적성
- dfs
- SEB 43
- 감정 일기장
- 백준
- 기술면접
- til
- seb
- 다이나믹 프로그래밍
- 프론트엔드
- 그리디 알고리즘
- BFS
- 회고
- 개인 프로젝트
- 프로그래머스
- Python
- 코테
- SEB43
- 감정일기장
- React quill
- useContext
- 브루드포스
- SEB43기
- 스택오버플로우
- 프리프로젝트
- 코드스테이츠
- Redux
- SEB 43기
- 프로젝트
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함