1×
Become a member
to unlock all features

Level Up!

Access all courses & lessons on egghead today and lock-in your price for life.

Autoplay

    Introduction to the in-depth Immer course

    Michel WeststrateMichel Weststrate
    javascriptJavaScript

    Using immutable data to store state has many interesting benefits. Immutable data makes it easy to trace state over time. It can be distributed easily, and by leveraging structural sharing we can leverage optimization techniques such as memoization.

    In this course we will build a multi user gift-list, in which we will discover how using immer doesn’t just significantly simplifies our state manipulation code. It also provides us with very useful tools such as patches that can help us to distribute changes, build undo/ redo, etc.

    Code

    Code

    Become a Member to view code

    You must be a Member to view code

    Access all courses and lessons, track your progress, gain confidence and expertise.

    Become a Member
    and unlock code for this lesson
    Discuss

    Discuss

    Transcript

    Transcript

    Instructor: In this video course, we are going to study the Immer library. The Immer library makes working with immutable data a lot easier. For that reason, it has become really popular. In this course, we're going to go pretty deep.

    Immer has a lot of features most people don't know about. In this course, we're going to build a small application in which someone can manage the gifts he wants to receive for his birthday, for example. Also, attendees can reserve the things that they want to be giving to make sure that people don't gift the same thing twice, and this application will become quite fancy.

    It will, for example, be possible to have multiple users working on the very same application. What's even more, people will be able to do, undo, and redo without breaking its address changes. This whole application will be driven by immutable data which captures the state in Immer. However, let's start very simple, shall we?