What Every Developer Must Know About Types of Browser Storage

Cess - Jul 15 '22 - - Dev Community

This post was originally published on Hackmamba

We use the browser every day to access the internet and view web pages but have we ever thought of how it stores data? The browser is crucial for saving information about the websites we visit. Storage types used by browsers differ, and it is vital to understand how they work.

This article will discuss the types of storage used by the browser and how they work.

Prerequisite

To follow along with this article, we will need the following:

  • Basic understanding of HTML and JavaScript
  • We can use Visual Studio Code or any other IDE of our choice

What Is Browser Web Storage?

Web storage is also known as Document object model storage (DOM storage). It is a client-side feature that gives web apps access to data storage methods and protocols. By client-side, we mean that the processing takes place on the user's computer.

Types of Storage in a Browser?

Here is a list of some common browser storage types:

  • Web Storage API (localStorage, sessionStorage)
  • Cookies
  • IndexedDB

Web Storage API

WebStorage API, also known as HTML5 storage, is a form of persistent storage that stores data on the client's computer. It consists of the following:

  • LocalStorage
  • SessionStorage

What Are LocalStorage and SessionStorage?

LocalStorage is one of the most used browser storage options. We store all our data on our computer permanently in localStorage. It saves our data to the point where we can still access it after we close and reopen our browser.

The data saved in localStorage does not expire until we delete it manually. To erase data from localStorage, use JavaScript or clear the browser cache.

SessionStorage is like localStorage but with a few differences. It only keeps data for a particular session. We store all our data on our computer temporarily in sessionStorage. When the session expires, i.e., when we close that browser or tab, our data is erased.

Each time we open two tabs with the same URL, the web browser creates its sessionStorage. A different window tab cannot access another sessionStorage data. For example, we can conduct separate transactions on an e-commerce site even if we open two browser tabs.

LocalStorage and sessionStorage store data as a key-value pair, but it must be either a number or a string.

Note: To store other data types like arrays or objects, we use JSON.stringify() to convert them into strings.

Where Is LocalStorage Stored?

In the user's profile, Goggle chrome saves web storage data in an SQLite file. We can find this file in the subfolder:

On Windows:

    \AppData\Local\Google\Chrome\User Data\Default\Local Storage
Enter fullscreen mode Exit fullscreen mode

On MacOS:

    ~/Library/Application Support/Google/Chrome/Default/Local Storage 
Enter fullscreen mode Exit fullscreen mode

Firefox also saves storage objects in the user's profile in an SQLite file called webappsstore.sqlite.

How to View LocalStorage and SessionStorage Data?

Follow these steps to view the data in localStorage and sessionStorage:

  • Open developer tools in Google chrome
  • Click on the application tab
  • Click on localStorage or sessionStorage

How to view localStorage and sessionStorage data img

How Do Localstorage and Sessionstorage Work?

Both localStorage and sessionStorage use the following methods:

  • setItem(): Add key/value to both local and sessionStorage
  • getItem(): Access a value stored in local and sessionStorage
  • removeItem(): Delete an item from local and sessionStorage
  • clear(): Delete all items from local and sessionStorage
  • key(): It helps us retrieve a key of an item from local and sessionStorage
    // setItem()
    window.localStorage.setItem('name', 'cess'); // The key is 'name', and the value is 
    'cess'

    // To convert arrays or objects to strings 
     const detail = { 
           name: 'cess',    
           job: 'developer',
     }; 
     window.localStorage.setItem('profile', JSON.stringify(detail));  // failure to convert to strings will result in 
     // an error

    // getItem() - it takes only one parameter, the key, and returns a string as the 
    // value. To retreieve the above "detail" object:
    window.localStorage.getItem('profile');  // "{name:"cess",job:"developer"}"

    // removeItem() -  It requires a key as a parameter 
    window.localStorage.removeItem('name');  // It will remove 'name' from the above 
    // object. To confirm if it worked:
    console.log(localStorage.getItem('name'));  

    // clear() - It does not accept any parameters
    window.localStorage.clear(); // will delete all the items stored in localStorage

    // key() - It allows us to get the key of a localStorage item using its index.
    var ourKey = window.localStorage.key(index);
Enter fullscreen mode Exit fullscreen mode

Limitations of Using LocalStorage and SessionStorage (Web Storage API)

LocalStorage and sessionStorage have the following limitations:

  • Insecure data: Avoid storing sensitive user data in localStorage
  • It can only store data on the client-side
  • Limited storage capacity: It has a 5MB storage limit that applies to all major browsers
  • It is synchronous, meaning each localStorage operation will run one at a time

What Is Cookie Storage?

A cookie is a small data file sent by a website to our device's hard drive or mobile browser. It saves client-side data, allowing users a more personalized web experience.

4KB to 1MB is the maximum storage size for cookies, and the browser saves them in name-value pairs.

What Are the Types of Cookie Storage?

There are two types of cookie storage:

  • Session cookies: Session cookies have no expiration date. When we exit our browser tab, our saved data is erased. On e-commerce sites, a session cookie keeps track of the items in a shopping cart. It stores these items and helps the browser remember them when it is time to check out.

  • Persistent cookies: Persistent cookies have an expiration date. It saves our information even after we close our browser, but they expire after a specific time. Its default time length is 30 minutes, but we can change it to any time using the expire or max-age attributes.

    document.cookie = "username=cess; expires=Thu, 19 Dec 2023 11:00:00  GMT "; 
Enter fullscreen mode Exit fullscreen mode

How to Create and Delete Cookies with Javascript?

We can use Javascript to create cookies with the document.cookie property:

    document.cookie = "username=cess";
    console.log(document.cookie);  // "username=cess"
Enter fullscreen mode Exit fullscreen mode

Set the expire parameter to a past date to delete cookies:

    document.cookie = "username=; expires=Wed, 19 feb 1985 01:00:00 GMT; path=/"; 
Enter fullscreen mode Exit fullscreen mode

Limitations of Using Cookie Storage

Cookies have the following limitations:

  • Limited storage capacity: It has a limit of 20 cookies per browser and a storage limit of 4KB to 1MB
  • Insecure data: Avoid storing sensitive user data in cookies
  • Since they are synchronous, web workers cannot access them
  • If the browser's security level is too high, it won't function

What Is the Difference Between SessionStorage, LocalStorage, and Cookies?

The following picture illustrates how cookies differ from local and sessionStorage:

difference between sessionStorage, localStorage and cookies img

What Is IndexedDB Storage?

IndexedDB is an inbuilt browser database that we use to store large quantities of data. It allows us to create high-quality web applications that we can use both online and offline.

Some of IndexDB's features include the following:

For more information on IndexedDB, click here.

Conclusion

The browser offers various storage options, each with pros and drawbacks. This article taught us about the different types of web storage and how to use them. Now we should be able to choose the proper storage that meets our needs.

Resources

Here are some resources we may find helpful:

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .