Redux Toolkit을 활용한 효율적인 상태관리 블로그 제목: Redux Toolkit 활용: 쉽고 빠른 상태 관리를 위한 해법

블로그 내용:

Redux Toolkit은 Redux의 ‘공식 방법’으로 사실상 Redux의 요구사항을 단순화 합니다. Redux Toolkit을 사용하면 당신은 액션 타입, 액션 생성자 함수, 리듀서 함수를 직접 작성할 필요가 없습니다. 대신 createSlice()라는 Redux Toolkit 함수를 사용하여 이 모든 것들을 한 번에 생성할 수 있습니다.

import { createSlice } from '@reduxjs/toolkit'

const counterSlice = createSlice({
  name: 'counter',
  initialState: 0,
  reducers: {
    increment: state => state + 1,
    decrement: state => state - 1
  }
})

export const { actions, reducer } = counterSlice

위의 코드에서 리듀서 함수는 더 이상 불변성을 직접 관리할 필요가 없습니다. Redux Toolkit은 ‘Immer’라는 라이브러리를 내부적으로 사용하여 불변성을 자동으로 처리합니다.

이제 실무에서 어떻게 활용할 수 있을지 알아봅시다. Redux Toolkit은 비동기 작업 처리를 위한 createAsyncThunk 함수를 제공합니다.

import { createAsyncThunk, createSlice } from '@reduxjs/toolkit'
import axios from 'axios'

export const fetchUserById = createAsyncThunk('users/fetchByIdStatus', async (userId, thunkAPI) => {
  const response = await axios.get(`/api/users/${userId}`)
  return response.data
})

const usersSlice = createSlice({
  name: 'users',
  initialState: {},
  reducers: {},
  extraReducers: {
    [fetchUserById.fulfilled]: (state, action) => {
      state[action.payload.id] = action.payload
    }
  }
})

export default usersSlice.reducer

위의 코드에서 createAsyncThunk는 Promise를 반환하는 함수를 인자로 받습니다. 이 함수 내에서는 서버로 데이터를 가져오거나, 저장하는 등의 비동기 작업을 처리하면 됩니다. 또한 extraReducers는 단일 액션 타입에 따라 여러 리듀서들을 실행할 수 있게 해줍니다.

응용 버전을 살펴보면, 복잡한 상태 객체를 관리하는 상황에서도 Redux Toolkit을 효과적으로 활용할 수 있습니다.

import { createSlice, createAsyncThunk } from '@reduxjs/toolkit'
import axios from 'axios'

export const fetchCommentsByPostId = createAsyncThunk('comments/fetchByPostIdStatus', async (postId, thunkAPI) => {
  const response = await axios.get(`/api/posts/${postId}/comments`)
  return response.data
})

const commentsSlice = createSlice({
  name: 'comments',
  initialState: {},
  reducers: {},
  extraReducers: {
    [fetchCommentsByPostId.fulfilled]: (state, action) => {
      action.payload.forEach(comment => {
        state[comment.id] = comment
      })
    }
  }
})

export default commentsSlice.reducer

위의 코드에서는 포스트 ID로 댓글들을 가져와서 상태에 저장하는 시나리오를 보여줍니다. fetchCommentsByPostId라는 비동기 액션을 통해 서버에서 데이터를 가져온 후, 이를 상태에 반영하는 부분은 extraReducers를 통해 처리합니다.

Redux Toolkit은 익히면 Redux 코드를 훨씬 더 간결하고 명확하게 만들 수 있는 도구입니다. 기본적인 사용법부터 비동기 작업 처리, 복잡한 상태 관리까지 쉽게 해결할 수 있으므로, 실무에서 많이 활용하게 될 것입니다.




Enjoy Reading This Article?

Here are some more articles you might like to read next:

  • Google Gemini updates: Flash 1.5, Gemma 2 and Project Astra
  • Displaying External Posts on Your al-folio Blog
  • Styled-components를 활용한 React 스타일링 블로그 제목: React 스타일링의 혁신, Styled-components를 활용한 강력한 CSS in JS 기법 마스터하기
  • 프론트엔드 프로젝트를 설계할 때 고려해야할 필수 13가지
  • React Native를 이용해 본격 크로스 플랫폼 모바일 앱 개발에 도전하기