Storing Data Beyond a Single User Session: A Progressive Web App Solution

When building a progressive web app (PWA), you may want to store information that persists beyond a single user session. This data should be accessible even when the user is offline, allowing them to continue using the app meaningfully. But how can we achieve this?

The Limitations of localStorage

One might think of using Window.localStorage, a longstanding API that stores data beyond a single session. However, it presents a few key problems. First, it’s synchronous, which can lead to performance issues. Second, it can’t be used in the context of a Worker or a ServiceWorker. Lastly, it only stores strings, which can be an inconvenience.

IndexedDB: A Powerful Alternative

Fortunately, there’s an alternative offline storage mechanism available in browsers called IndexedDB. It’s a transactional database system that lets you store and retrieve objects indexed with a key. Although it’s powerful, its API can be complex and overwhelming.

IDB-Keyval: A Simple Abstraction

That’s where IDB-Keyval comes in – a super-simple-small promise-based keyval store implemented with IndexedDB. Its API is essentially equivalent to localStorage, but with a few lovely differences. It’s promise-based, allowing for non-blocking operations, and it can store anything structured-clonable, such as numbers, arrays, objects, dates, blobs, and more.

Using IDB-Keyval in a React App

Let’s demonstrate how to use IDB-Keyval in a TypeScript React app. We’ll create a simple app that enables users to choose between a dark mode and the regular display. We’ll then persist this preference using IDB-Keyval, allowing it to work both online and offline.

Implementing IDB-Keyval as a React Hook

To take it a step further, let’s create a reusable React hook called usePersistentState. This hook is modeled after the API of useState and allows us to persist state beyond page refreshes.

The Benefits of Offline Storage

Offline storage leads to better user experiences. By using IDB-Keyval, we can build PWAs that provide users with a seamless experience, even when they’re offline. Whether you’re building a React, Vue, or Angular app, this solution can help you achieve offline storage with ease.

Get Started with LogRocket

Want to improve your app’s performance and user experience? Sign up for LogRocket, a modern React error tracking tool, and get started in minutes. With LogRocket, you can create better digital experiences for your users.

Leave a Reply