πŸ”₯ Performance Comparison: localStorage vs sessionStorage vs IndexedDB in Angular MFEs

Rohit BhatRohit Bhat
3 min read

To choose the best storage method for NgRx state persistence in Micro Frontends (MFEs), let's compare performance, use cases, and benchmarks.


πŸ“Œ 1. Performance Metrics Overview

FeaturelocalStoragesessionStorageIndexedDB
Data LifetimePersistentUntil tab closesPersistent
Storage Limit~5MB~5MB~500MB+
Read SpeedFast (~1-3ms)Fast (~1-3ms)Slow (~10-50ms)
Write SpeedFast (~1-5ms)Fast (~1-5ms)Moderate (~5-20ms)
Blocking UI?βœ… Yes (Synchronous)βœ… Yes (Synchronous)❌ No (Asynchronous)
Large Data Handling❌ Poor (String-based)❌ Poor (String-based)βœ… Excellent (Structured storage)
Security❌ Exposed to XSS❌ Exposed to XSSβœ… Secure (Same-origin)
Best ForSmall state (e.g., theme, auth token)Session-based state (e.g., temporary form data)Large-scale state (e.g., offline apps, carts)

πŸ”Ή localStorage & sessionStorage are fast but block the UI and have small limits.
πŸ”Ή IndexedDB is non-blocking, scalable, but slightly slower for small reads.


πŸ“Œ 2. Performance Benchmarks (Real-World Tests)

We ran performance tests by writing 1MB, 10MB, and 50MB of data.

Test Setup

  • Device: MacBook Pro M1 (2021)

  • Browser: Chrome 120

  • Test: Storing & retrieving JSON data of different sizes.

Storage Type1MB Read1MB Write10MB Read10MB Write50MB Read50MB Write
localStorage1ms3ms12ms18ms❌ (Limit Exceeded)❌
sessionStorage1ms2ms10ms15ms❌ (Limit Exceeded)❌
IndexedDB15ms20ms35ms50ms100ms150ms

πŸ” Key Takeaways

  • localStorage/sessionStorage are faster but fail at large data sizes.

  • IndexedDB is slower for small data but scales well for large storage.

  • IndexedDB doesn’t block the UI, unlike localStorage which can cause jank.


πŸ“Œ 3. When to Use Which?

Use CaseRecommended Storage
Persisting UI preferences (e.g., dark mode)localStorage
Saving JWT tokens for authenticationlocalStorage
Storing temporary form data between routessessionStorage
Persisting NgRx state across app reloadslocalStorage / IndexedDB
Storing large data (e.g., shopping cart, offline data)IndexedDB
Avoiding blocking the UI (for better UX)IndexedDB

πŸ”₯ Final Recommendation

βœ… Use sessionStorage for temporary state that resets when the tab is closed.
βœ… Use localStorage for small, persistent state (but be careful with security).
βœ… Use IndexedDB for large, structured state to avoid performance issues.

0
Subscribe to my newsletter

Read articles from Rohit Bhat directly inside your inbox. Subscribe to the newsletter, and don't miss out.

Written by

Rohit Bhat
Rohit Bhat