상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - React에서 useReducer 훅은 어떻게 사용하나요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
`useReducer` 훅은 <a href='https://sangseek.com/sangseeks/React/ko'>React</a>에서 상태 관리를 위한 강력한 도구로, 특히 복잡한 상태 로직을 다루거나 여러 하위 컴포넌트에서 상태를 공유해야 할 때 유용합니다. `useReducer`는 <a href='https://sangseek.com/sangseeks/Redux/ko'>Redux</a>와 유사한 패턴을 사용하여 상태를 업데이트하는데, 이로 인해 상태 변화의 흐름을 명확하게 관리할 수 있습니다. 기본 사용법 `useReducer`는 두 개의 인자를 받습니다: 리듀서 함수와 <a href='https://sangseek.com/sangseeks/초기 상태/ko'>초기 상태</a>입니다. 리듀서 함수는 현재 상태와 액션을 인자로 받아 새로운 상태를 반환합니다. 1. 리듀서 함수 정의 리듀서 함수는 다음과 같은 형태를 가집니다: ```javascript const reducer = (state, action) => { switch (action.type) { case 'INCREMENT': return { count: state.count + 1 }; case 'DECREMENT': return { count: state.count - 1 }; default: return state; } }; ``` 위의 예시에서 `reducer`는 상태 객체와 액션 객체를 받아서 새로운 상태를 반환합니다. 2. 초기 상태 정의 초기 상태는 보통 객체 형태로 정의됩니다: ```javascript const initialState = { count: 0 }; ``` 3. useReducer 훅 사용 이제 `useReducer`를 사용하여 상태를 관리할 수 있습니다: ```javascript import React, { useReducer } from 'react'; const Counter = () => { const initialState = { count: 0 }; const reducer = (state, action) => { switch (action.type) { case 'INCREMENT': return { count: state.count + 1 }; case 'DECREMENT': return { count: state.count - 1 }; default: return state; } }; const [state, dispatch] = useReducer(reducer, initialState); return ( <div> <p>Count: {state.count}</p> <button onClick={() => dispatch({ type: 'INCREMENT' })}>Increment</button> <button onClick={() => dispatch({ type: 'DECREMENT' })}>Decrement</button> </div> ); }; export default Counter; ``` 설명 1. 상태와 디스패치 함수 : `useReducer`는 현재 상태와 `dispatch` 함수를 반환합니다. `dispatch` 함수는 액션을 리듀서에 전달하여 상태를 업데이트합니다. 2. 액션 객체 : 액션은 일반적으로 `type` 속성을 가진 객체입니다. 이 `type`은 리듀서에서 어떤 작업을 수행할지를 결정합니다. 3. 상태 업데이트 : 버튼 클릭 시 `dispatch`를 호출하여 액션을 리듀서에 전달하고, 리듀서는 현재 상태와 액션을 기반으로 새로운 상태를 반환합니다. 장점 - 명확한 상태 관리 : 상태 업데이트 로직이 리듀서에 집중되어 있어, 상태 변화의 흐름을 쉽게 추적할 수 있습니다. - 복잡한 상태 로직 : 여러 상태를 관리하거나 상태 업데이트가 복잡한 경우에 유용합니다. - 컴포넌트 간 상태 공유 : 여러 컴포넌트에서 동일한 상태를 사용할 수 있도록 쉽게 구조화할 수 있습니다. 결론 `useReducer`는 React에서 상태 관리를 위한 강력한 도구로, 특히 복잡한 상태 로직을 다루는 데 유용합니다. 리듀서 패턴을 통해 상태 변화의 흐름을 명확하게 관리할 수 있으며, 여러 컴포넌트 간의 상태 공유도 용이합니다. 이를 통해 더 나은 유지보수성과 가독성을 가진 코드를 작성할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기