React Hooks are so powerful and especially some additional hooks.
Do you know there is an alternative to useState called useReducer hook? It is used to manage more complex states.
Let's look into detail 🧵👇🏻
Usually, the useState hook is used to tackle states in React where you can pass the initial state and React preserves state for you between re-renders
What if you need to manage more complex states? Here useReducers comes into play
Similar to useState, the useReducer hook also returns a pair of values. Let's see what these two things are
The first value is `undefined` which is the current state (it is undefined because we didn't pass any initial state in the useReducer hook)
The second value is a dispatch function using which we can update our state.
The useReducer hook accepts 3 parameter
1. reducer 2. Initial state 3. init
Now we know that useReducer takes three parameters and return two values
Here is the complete syntax 👇🏻
Let's try to see this into action.
I just implemented a basic code here. Basically, I am calling dispatch function on button click which will eventually call reducer function
So far we haven't seen how the state can be managed using this.
Before that one thing to note here is that useReducer is for handling more complex states hence it is recommended to passing the current state as an object
Now we can simply update our state by passing the state parameter in the reducer function.
Something like this 👇🏻
Now every time I click on the button my state will be incremented by 1 because the reducer function returning the new state by adding one to the previous state.
The reducer function accepts the second argument as well known as "action" using which we can tell the reducer function that what operations need to perform on the state.
Generally, we can pass different actions through dispatch to reducer via an object.
This is how you can pass different types of operations in the reducer function using the action parameter.
What if I want to pass some values through dispatch to the reducer function?
Here is "payload" comes into play. It is used to pass the value which represents the payloads of the action.
For example, suppose I want to pass "temp" variable 👇🏻
CSS is an amazing and unique language that servers a great purpose. We can make our website visually good using CSS. It describes the presentation of web pages, including typography, layouts, color, etc
Let's break it down 🧵👇🏻
CSS is a stylesheet language that serves one great purpose. It makes your website visually good
Consider this amazon website with and without CSS 👇🏻
I hope you got it why CSS is important for web development. Alright let's move onto actually discussion that how you start learning it