Hey!
How is your day going? I mean, really, how it is going?
As I mentioned on the last post, it's been now 4 months that I am working as a remote front end developer for Rewatt Power.
In this time, I have learnt more than the entire last year learning by myself, and even tho I am still struggling, I am feeling much more confident now that when I started.
One of the things I learned at work is Redux.
I am not going to lie, in the beginning, I couldn't grasp Redux, but now that I got a better idea about how it works, I want to share it with you.
But first, let me present you something I have been cooking...
To show you how Redux works, or any other topic I'll learn as a front-end developer, I decided to create a short format that I found work best for me when learning a new topic.
I called them React Tips for Newbies.
These React Tips are going to consist of two parts:
First, a CodeSandbox.
codewhat 🤔??
With CodeSandBox you are going to be able to see/explore a working code example on how Redux works, modifying, copying or forking the code in any way you want.
The second is a post where I explained the concepts that we are going to use on the Codesandbox, this way you can make sense of the code and you already have a working example for your use.
Let's get started with the first React Tip for Newbies
So what is Redux?
Redux is a predictable state container for JavaScript apps.
What does this statement really means?
It means that Redux helps you manage the state of your application, making easier to do things like passing props from one component to another.
In our example, we are going to see how does it work, with the simplest example possible. We first need to explain three basic concepts that we will be working on Redux.
Actions are payloads of information that send data from your application to your store. They are the only source of information for the store.
Reducers specify how the application's state changes in response to actions sent to the store. Remember that actions only describe what happened, but don't describe how the application's state changes.
The Store is the object that brings them together.
You remember how I mentioned before that each React Tip for Newbies is going to have a post and a code example that you are going to be able to play with?
Don't panic, we are going to go slow so you can understand how everything fits together.
If you have never seen a CodeSandbox, spend some time to get familiar with the UI, it's pretty awesome!
The first thing I want you to do is find the reducer.js file inside the Counter folder.
In there you are going to see two of the main components of Redux, our actions and reducer.
In most of the tutorials, you are going to see that they separate actions and reducers in two different files. I personally find much easier to keep them on a single file, we can do this by using the Redux Actions package.
If you don't remember the purpose of the reducer and the actions, I suggest you to read again the official descriptions of this components.
The third component of Redux is the store, you can check how to implement the store by checking the index.js in the src folder.
The more important thing about the store is that we need to import the reducer.js file to pass it to the store.
The store will 'store' and change the state depending on the actions of the reducer.
Those are the three Redux components that you need to be familiar with to understand Redux.
If you are curious, you probably have clicked in one of the buttons to change the score. We are going to use these buttons to show how Redux works.
We now have set up the actions, reducer and the store.
This is the way I usually do it.
First, I create the reducer (remember our reducer is inside the Counter folder, the reducer.js file).
In our example, you can see that there is one reducer with a switch statement where we either decrease or add an unit to the state, we have also set up an initial state where number = 2.
Then I have created actions matching this switch statements, and export them. This actions are going to be used by the component to change the state.
Here is another important thing you should know.
If you are going to use actions on a component, is a good practice to split the component into two parts. You can see them inside the _Counte_r folder, there are a component and a container file.
The main difference between component vs container.
The container passes the state and the actions that we want the component to use. In fact, if you check container.js, you will see that we pass two things:
First using mapStateToProps we pass the state, this is coming from the store (we set this up on the index.js inside the src folder remember).
Secondly, we import the **actions **from the reducer and pass them to the component with mapDispatchToProps.
We also import the component.jsx.
Think about container.js like a smart component, it has passed the state and the actions to component.jsx. That's why usually the component is called a dummy component, it has no idea of what the state/actions if the container doesn't provide them.
The container.js file (smart component) imports the component.jsx (dummy component), then we will use the container.js to render, as you can see on the index.js inside the src folder.
We have the ability to use the state and the actions that we passed in our component, check the component.js file inside the Counter folder, we can grab the actions and the state from the props!!
As you can see, on the two buttons we have set up the actions that we passed, this results on the buttons modifying the state of the application thanks to Redux.
Since the component is aware of the changes on the state (we passed the state on the container.js file), when we click the button, the action is fired and the state is modified, resulting in the change on the number displayed on the screen.
Do you get it now?
Do you find this format useful?
If you still find it hard to understand, please give some feedback on Twitter or send me an email to daniel@danielgg.com.
I know it is a little tricky to get it at first glance, but hey, now you have a reference so it's a matter reference this example anytime you got any question.