Lecture 6: Advanced State Management
Objective:
You will learn advanced state management techniques in React, including the use of reducers, context, and providers, as well as building custom hooks. By the end, you will refactor your Todo list application to use context to minimize the need for prop passing.
Duration:
Aiming for 1 hour
6.1: Introduction to Reducers
Learning Goals:
- Understand the concept of reducers in state management
- Learn how to use the
useReducer
hook in React
Outline:
-
Understanding Reducers
- What is a reducer?
- Benefits of using reducers for complex state logic
-
Using the
useReducer
Hook- Syntax and usage
- Initial state and dispatching actions
Activities:
- Create a simple counter using
useReducer
- Modify the counter to handle more complex actions
Resources:
6.2: Context and Providers
Learning Goals:
- Understand the concept of context in React
- Learn how to use the
createContext
andProvider
components
Outline:
-
Understanding Context
- What is context?
- When and why to use context
-
Using Context and Providers
- Creating a context
- Using the
Provider
to pass down data
Activities:
- Create a theme context to manage light and dark modes
- Use the context in various components to toggle themes
Resources:
6.3: Combining Reducers and Context
Learning Goals:
- Learn how to combine
useReducer
and context for state management - Understand the benefits of this approach
Outline:
-
Combining
useReducer
and Context- Setting up the context with
useReducer
- Providing the state and dispatch function
- Setting up the context with
-
Using the Combined Approach in Components
- Consuming the context in child components
- Dispatching actions from child components
Activities:
- Refactor the theme context to use
useReducer
- Implement complex state logic with the combined approach
Resources:
6.4: Building Custom Hooks
Learning Goals:
- Understand the purpose and benefits of custom hooks
- Learn how to build and use custom hooks
Outline:
-
Introduction to Custom Hooks
- What are custom hooks?
- When to create custom hooks
-
Building Custom Hooks
- Extracting logic into a custom hook
- Using the custom hook in components
Activities:
- Create a custom hook for fetching data
- Use the custom hook in multiple components
Resources:
6.5: Refactoring the Todo List with Context
Learning Goals:
- Apply the learned concepts to refactor the Todo list application
- Minimize prop passing by using context
Outline:
-
Project Overview
- Understanding the current structure and prop drilling issues
- Planning the refactor
-
Refactoring the Todo List
- Creating a context for Todo state
- Using
useReducer
for state management - Providing and consuming the context
Activities:
- Refactor the existing Todo list to use context and reducers
- Test the refactored application for functionality
Resources:
6.6: Review and Enhancement
Learning Goals:
- Review the refactored Todo list application
- Discuss potential enhancements and optimizations
Outline:
-
Review the Refactored Application
- Walk through the refactored code
- Discuss the improvements and remaining issues
-
Enhancing the Todo List
- Adding new features (e.g., filter todos, persist state)
- Optimizing performance
Activities:
- Implement additional features in the Todo list
- Optimize the Todo list for performance and scalability
Resources:
Reading Material with Examples
Reducers
// counterReducer.js
export const initialState = { count: 0 };
export function counterReducer(state, action) {
switch (action.type) {
case "increment":
return { count: state.count + 1 };
case "decrement":
return { count: state.count - 1 };
default:
throw new Error();
}
}