Quick Start
Last updated
Was this helpful?
Last updated
Was this helpful?
:::tip What You'll Learn
How to set up and use Redux Toolkit with React Redux
:::
:::info Prerequisites
Familiarity with
Knowledge of React terminology: , , , and
Understanding of
:::
Welcome to the React Redux Quick Start tutorial! This tutorial will briefly introduce you to React Redux and teach you how to start using it correctly.
This page will focus on just how to set up a Redux application with Redux Toolkit and the main APIs you'll use. For explanations of what Redux is, how it works, and full examples of how to use Redux Toolkit, see .
For this tutorial, we assume that you're using Redux Toolkit and React Redux together, as that is the standard Redux usage pattern. The examples are based on where all the application code is in a src
, but the patterns can be adapted to whatever project or folder setup you're using.
Add the Redux Toolkit and React Redux packages to your project:
Create a file named src/app/store.js
. Import the configureStore
API from Redux Toolkit. We'll start by creating an empty Redux store, and exporting it:
This creates a Redux store, and also automatically configure the Redux DevTools extension so that you can inspect the store while developing.
Once the store is created, we can make it available to our React components by putting a React Redux <Provider>
around our application in src/index.js
. Import the Redux store we just created, put a <Provider>
around your <App>
, and pass the store as a prop:
Add a new file named src/features/counter/counterSlice.js
. In that file, import the createSlice
API from Redux Toolkit.
Creating a slice requires a string name to identify the slice, an initial state value, and one or more reducer functions to define how the state can be updated. Once a slice is created, we can export the generated Redux action creators and the reducer function for the whole slice.
Next, we need to import the reducer function from the counter slice and add it to our store. By defining a field inside the reducers
parameter, we tell the store to use this slice reducer function to handle all updates to that state.
Now we can use the React Redux hooks to let React components interact with the Redux store. We can read data from the store with useSelector
, and dispatch actions using useDispatch
. Create a src/features/counter/Counter.js
file with a <Counter>
component inside, then import that component into App.js
and render it inside of <App>
.
Now, any time you click the "Increment" and "Decrement buttons:
The corresponding Redux action will be dispatched to the store
The counter slice reducer will see the actions and update its state
The <Counter>
component will see the new state value from the store and re-render itself with the new data
That was a brief overview of how to set up and use Redux Toolkit with React. Recapping the details:
:::tip Summary
Create a Redux store with configureStore
configureStore
accepts a reducer
function as a named argument
configureStore
automatically sets up the store with good default settings
Provide the Redux store to the React application components
Put a React Redux <Provider>
component around your <App />
Pass the Redux store as <Provider store={store}>
Create a Redux "slice" reducer with createSlice
Call createSlice
with a string name, an initial state, and named reducer functions
Reducer functions may "mutate" the state using Immer
Export the generated slice reducer and action creators
Use the React Redux useSelector/useDispatch
hooks in React components
Read data from the store with the useSelector
hook
Get the dispatch
function with the useDispatch
hook, and dispatch actions as needed
:::
The counter example app shown here is also the
Here's the complete counter application as a running CodeSandbox:
The comes with this same project setup already configured.
Redux requires that . However, Redux Toolkit's createSlice
and createReducer
APIs use inside to allow us to .
We recommend going through , which will give you a complete understanding of how Redux works, what Redux Toolkit and React Redux do, and how to use it correctly.