Simplifying State Management in React Native

Book description

Make fact-based decisions by comparing different solutions and learning popular ways to manage state in React Native with clear guidelines and recommendations by a React Native expert

Key Features

  • Explore the big picture of state management in React Native using the most simplified version
  • Implement state management solutions by building a social media clone app
  • Compare different state solutions in a contained environment to choose the best fit for your future projects

Book Description

Managing state in a React Native app can be challenging as it is one of the most difficult concepts to grasp while learning React Native. This is because there are so many ways to do it, and because there is a lack of clear guidelines on what should be used and why.

Simplifying State Management in React Native is a comprehensive introduction for those who are new to creating robust React Native apps that will have you up to speed in no time. You'll get to grips with the different state management strategies and libraries available. As you progress through the chapters, you'll try out different solutions, as well as compare and choose which solution is perfectly suited to your future projects and personal preferences. Finally, you'll create a social media clone app using all the concepts and examples that you've learned in this book.

By the end of this book, you'll be able to take on existing projects that use various state management strategies and libraries, and confidently make decisions about state management.

What you will learn

  • Start out by going over the basic ReactJS “mindset”
  • Explore all that ReactJS has to offer to manage state in apps by building an app
  • Understand existing state management libraries such as Redux, MobX, XState, Jotai, and React Query
  • Decide which libraries you want to use in your apps
  • Design a social media app to fully understand state management
  • Try out all the solutions presented in the book in a social media clone app

Who this book is for

This book is for junior developers, React Native developers, and mobile app developers who are already using React Native, but are also on the lookout for advice and for a broader view to manage the state and changes in their applications. Basic knowledge of ReactJS and React Native, as well as familiarity with JavaScript and general mobile app development concepts are needed to grasp the topics covered in this book.

Table of contents

  1. Simplifying State Management in React Native
  2. Contributors
  3. About the author
  4. About the reviewers
  5. Preface
    1. Who this book is for
    2. What this book covers
    3. To get the most out of this book
    4. Download the example code files
    5. Download the color images
    6. Conventions used
    7. Get in touch
    8. Share Your Thoughts
    9. Download a free PDF copy of this book
  6. Part 1 – Learn the Basics: Intro to React, States, Props, Hooks, and Context
  7. Chapter 1: What are React and React Native?
    1. Understanding the history of ReactJS
      1. The predecessors
      2. And then there was React
    2. Thinking in React (the React mindset)
    3. Understanding cross-platform software development
    4. Going over the history of React Native
    5. Reviewing examples of popular apps using React Native
    6. Summary
  8. Chapter 2: Managing State in a Simple React App
    1. Technical requirements
    2. What is state and how is it different from props?
    3. What are stateful and stateless components?
    4. What are hooks and why use them?
      1. Which hooks should you know?
    5. Setting up the example app
      1. Environment setup
      2. App structure
    6. Summary
    7. Further reading
  9. Part 2 – Creating a Real, Working App
  10. Chapter 3: Planning and Setting Up the Funbook App
    1. Technical requirements
    2. Planning the needed surfaces and components
    3. Planning data flows in the app
    4. Getting comfortable previewing and debugging the app
    5. Summary
    6. Further reading
  11. Chapter 4: Styling and Populating the Funbook App
    1. Technical requirements
    2. Creating and styling components
    3. Pulling in data for the app
    4. Summary
    5. Further reading
  12. Part 3 – Exploring Various Libraries for State Management in React Native
  13. Chapter 5: Implementing Redux in Our Funbook App
    1. Technical requirements
    2. What is Redux? A brief history
    3. Installing and configuring Redux
      1. Dispatching actions
    4. Adding Redux functionalities to the app
      1. User login state walkthrough
      2. Using Redux for liked images
      3. Combining various pieces of global state
      4. Taking advantage of Redux Toolkit for creating actions
      5. Fetching data
      6. Replacing the context
    5. Debugging
    6. Summary
    7. Further reading
  14. Chapter 6: Using MobX as a State Manager in a React Native App
    1. Technical requirements
    2. Going over MobX concepts
    3. Configuring MobX in the Funbook app
    4. Using MobX for FavoritedImages
      1. Creating the store
      2. Fetching data
      3. Adding actions
      4. Deriving data from state
    5. Summary
    6. Further reading
  15. Chapter 7: Untangling Complex Flows in React Native Apps with XState
    1. Technical requirements
    2. What are finite state machines?
    3. What is XState – high-level concepts
    4. Configuring XState in the Funbook app
    5. Using XState for the FavoritedImages surface
      1. Configuring context and components
      2. Fetching image data
      3. Managing the image in the image modal
      4. Liking images
    6. Summary
    7. Further reading
  16. Chapter 8: Integrating Jotai in a React Native App
    1. Technical requirements
    2. What is Recoil and an atomic state?
    3. What is Jotai?
    4. Configuring Jotai in the Funbook app
    5. Using Jotai for ListOfFavoritedImages
      1. Fetching data with Jotai
      2. Reading and writing atoms
      3. Adding read-write functionality to the imageListAtom
      4. Implementing the Like button
    6. Summary
    7. Further reading
  17. Chapter 9: Using React Query for Server-Side-Driven State Management
    1. Technical requirements
    2. What is React Query and why is it in this book?
    3. Installing and configuring React Query
    4. Using React Query for data fetching
      1. Fetching image data
    5. Other React Query Functionalities
    6. React Query utilities for React Native
    7. Summary
    8. Further reading
  18. Part 4 – Summary
  19. Chapter 10: Appendix
    1. Bonus content
  20. Index
    1. Why subscribe?
  21. Other Books You May Enjoy
    1. Packt is searching for authors like you
    2. Download a free PDF copy of this book

Product information

  • Title: Simplifying State Management in React Native
  • Author(s): Aleksandra Desmurs-Linczewska
  • Release date: January 2023
  • Publisher(s): Packt Publishing
  • ISBN: 9781803235035