Skip to content

Latest commit

 

History

History
135 lines (85 loc) · 4.75 KB

lesson-1-5.md

File metadata and controls

135 lines (85 loc) · 4.75 KB

< Back to Overview

Lesson 1.5: React Hooks

This assignment will teach you the following:

  • Side-effects
  • Custom Hooks
  • Fragments

Instructions

Getting Started:

Merge your pull request from the previous lesson (if you haven't already):

View tutorial

Checkout your main branch and pull changes:

git checkout main
git pull

Create a new local branch to work on separate from the main branch:

git checkout -b lesson-1-5

Now, open the project directory in your code editor and continue to the next section.

Task List:

Save Todo List in Storage

So far you've built a todo list that allows you to add as many new items as you want, but what happens when you refresh the page? The list disappears!

In this lesson, you will learn how to save your list in local browser storage so it persists between page loads.

  • Open /src/App.js
  • Define a useEffect React hook with todoList as a dependency
  • Inside the side-effect handler function, save the todoList inside localStorage with the key "savedTodoList"
    • Hint: localStorage.setItem method
  • Run your application and view in browser
    • Enter a new todo in "Add Todo" form and submit
    • Open your Local Storage panel in the DevTools
      • In Chrome: DevTools > Application > Local Storage > localhost
    • Verify that your "savedTodoList" item exists
    • Notice that the value, however, is not readable (see below)

Local Storage with List saved as Object

  • Open /src/App.js
  • Update your side-effect function to convert todoList to a string before saving in localStorage
    • Hint: JSON.stringify method
  • View your application in browser
    • Clear your Local Storage
      • In Chrome: DevTools > Application > Storage > Click "Clear site data"
    • Repeat the same steps from above
    • Notice that the value is completely readable as a string (see below)

Local Storage with List saved as Object

Now your list is saved in Local Storage, but when you refresh the page? It still disappears!

This is because we wrote the list data to Local Storage but we aren't reading it when the application is rendered. Let's fix that:

  • Open /src/App.js
  • Update the default state for todoList to read your "savedTodoList" item from localStorage
    • Hint: localStorage.getItem method
  • View your application in browser
    • Notice that there is an error, todoList is not an Array

How could our list not be an Array? Right! We turned it into a string before saving in Local Storage. So now that we're ready to use the value, we need to turn it back into an Array.

  • Open /src/App.js
  • Update your default state to parse the value of the "savedTodoList" item
    • Hint: JSON.parse method
  • View your application in browser
    • Notice that your previous todo item(s) are still visible after refreshing the page

Create Custom Hook

  • Open /src/App.js
  • Above the App functional component, create a new function named useSemiPersistentState which will be a custom hook
  • Cut (copy/remove) the useState and useEffect hooks from App into useSemiPersistentState
  • Add a return statement in useSemiPersistentState that returns the todoList state variable and setter in an Array (just like how it's returned from the useState hook)
  • Update App to use the new custom hook
    • Hint: Copy the useState hook from before, but change useState to the custom hook useSemiPersistentState (no arguments)
  • View your application in browser
    • Verify that your Todo List still appears correctly

Fragments

  • Open /src/App.js and update the JSX to use a Fragment

Final Result

Lesson 1.5 Result

Final Step:

Check the status of your local repository to double-check the changes you made:

git status

Stage the file(s) that you edited:

git add .

Check the status again and notice that the changes from before are now staged:

git status

Create a commit for the changes you made and add a message describing the changes you made:

Note: Replace <message> with your message

git commit -m "<message>"

Push your commit to the remote repository (visible in GitHub):

git push

Check the log to make sure your commit has been published:

git log --oneline

Create a pull request and submit:

View instructions


Created by Code the Dream