The Beginner’s Guide to React Redux

Gone are the days where state can be an afterthought for your web project. Websites are handling more data live than they ever have before – but that doesn’t need to be a scary thing.

Redux is an open-source JavaScript library for managing the state of a web application. It is essential to know the state of each component in modern applications as they consist of different UI components that interact with each other. It is typically done at the component level in a framework like React.

Redux enables you to manage the state of an entire application using a single immutable object. It allows users to easily manage the global state and access the state of any connected component. The best part is that Redux can be integrated into any application from applications running plain Javascript to ones using frameworks like React, Angular, and Vue. In this tutorial, we’ll be using React Redux – but there are very similar implementations for whatever type of application that you are creating.


Core Components of Redux

Redux introduces a couple of new components to an application to facilitate this state management.

  • Actions - Actions are used to send data from the application to the Redux store. A typical action consists of the type property and an optional payload property.
  • Reducers - This is a function that accepts the current state and action as arguments and returns the updated state according to the action.
  • Store - This is the heart of Redux where the state is stored. The state is kept in plain JavaScript objects and arrays.

Creating a Simple Redux Application

In this section, we’ll create a simple to-do application using React and Redux.

Step 1 - Create the sample React App

Install the create-react-app package, create an app named “redux-to-do” and install Redux.

npm install -g create-react-app

create-react-app redux-contact-app

npm install --save redux react-redux


Step 2 - Create the folders for Redux

Create the following actions, reducers, and store folders in the src folder to facilitate Redux functions, and then fill them with the following javascript files:

Step 3 - Create the Actions

First, in our actionTypes.js. We’ll export the actionType for every action object we create:

export const CREATE_NEW_TODO = 'CREATE_NEW_TODO';

export const REMOVE_TODO = 'REMOVE_TODO';

Step 4 - Create a toDoActions.js file.

This will hold all the actions of the application, which in our case are the create and delete actions.

https://gist.github.com/LiorB-D/6206000cc36b14003f8c237de8b08b20

Step 5 - Create the Reducers

Create the toDoReducer.js file to connect the actions with the state stored in the Redux store:

https://gist.github.com/LiorB-D/fc1572ed0fc35045c63a5e4f4a0e04e7

Additionally, create an index.js file in the reducers folder to combine the reducers.

https://gist.github.com/LiorB-D/4085aab1e3d9e9ff4ae834b4963d2890

Step 6 - Create the Store

Create a file named configureStore.js to initialize the store and connect to the reducers.

https://gist.github.com/LiorB-D/1256f6114a347cc33fe4ac15589bf6cf

Step 7 - Update the index.js file in the application root

We will import the react-reduce provider and store and wrap the component with the Redux store.

https://gist.github.com/LiorB-D/26dc730777f92fb051dbbfce70e2cd09

Step 8 - Update the App.js File

In this step, we will render the application with the specified components and connect with Redux to obtain the state of each component.

https://gist.github.com/LiorB-D/6828d6d7ffa693b853d4b426f6b511e0

Note - The CSS classes are derived from the Bootstrap CSS framework. So you will have to link the Bootstrap stylesheet with the application. It can be done by adding the URL of the Bootstrap CSS file to the head section of the index.html file in your public folder.

Step 8 - Run the application

Use the npm run command to build and run the application. It will start the application on your default browser. Add some tasks and try it out.

That's it and you have successfully created a to-do application that manages the state via Redux!

If your local machine is slowing your development down, try Codesphere. Codesphere is an intuitive web IDE and cloud provider that lets you code, debug, and deploy all with the power of the cloud!

Happy Coding!