Implement useSessionStorage() Custom Hook in React [Interview]
Understand the code implementation of useSessionStorage custom hook in react that will help to efficiently manager session storage in application.
Anuj Sharma
Last Updated Nov 15, 2025
![Implement useSessionStorage() Custom Hook in React [Interview]](/_next/image?url=https%3A%2F%2Ftwijvresuxjxyhisasvd.supabase.co%2Fstorage%2Fv1%2Fobject%2Fpublic%2Fblog-images%2F5bf882d3-0967-44f5-bb29-5f33706cdfa6%2Fpattern-1763207973827-421m1d.png&w=3840&q=75&dpl=dpl_H4qwCuz3yWRX9zEfyLCQBYGw8NUB)
useLocalStorage and useSessionStorage is most widely used custom hooks to simplify the interaction with localStorage and sessionStorage at the application level and provide a clean way for interaction.
In this blog, Let's understand the implementation code of useSessionStorage custom hook in react.
How to Approach
While exploring the approach, its important to know that useSessionStorage custom hook in react will internally going to use the window.sessionStorage object only, and convert the object into string using JSON.stringify() function.
As part of the custom hook, we need to handle the set and get the session storage values, and introduce error handing at the common place under useSessionStorage custom hook, to handle any runtime errors.
Implementation of useSessionStorage Custom Hook
Let's checkout the code implementation and explanation of the useSessionStorage hook.
Custom Hook Code
import { useState } from 'react';
const useSessionStorage = (key, initialValue) => {
const [storedValue, setStoredValue] = useState(() => {
try {
const item = window.sessionStorage.getItem(key);
return item ? JSON.parse(item) : initialValue;
} catch (error) {
console.error(error);
return initialValue;
}
});
const setValue = (value) => {
try {
setStoredValue(value);
window.sessionStorage.setItem(key, JSON.stringify(value));
} catch (error) {
console.error(error);
}
};
return [storedValue, setValue];
};
export default useSessionStorage;
Step by Step Code Explanation
- useSessionStorage Function: Define the custom hook function that takes two parameters, key (for sessionStorage key) and initialValue.
- storedValue: Initialize state using useState and try to retrieve the value from sessionStorage based on the provided key. If no value is found, the initialValue is used.
- setValue Function: Define a function to update the storedValue in state and synchronize the sessionStorage with the new value.
- Return: Return an array containing storedValue and setValue to be used in components.
Understand useSessionStorage Hook Usage
Let's understand the useSessionStorage usage with a simple example of setting the useName key in the session storage.
import React from 'react';
import useSessionStorage from './useSessionStorage';
const App = () => {
const [name, setName] = useSessionStorage('userName', 'Guest');
const handleNameChange = (e) => {
setName(e.target.value);
};
return (
<div>
<input type="text" value={name} onChange={handleNameChange} />
<p>Hello, {name}!</p>
</div>
);
};
export default App;
In this example, we import the useSessionStorage custom hook and use it to manage the 'userName' key in sessionStorage with a default value of 'Guest'. We then update the name value based on user input in an input field.
Further Reading
A seasoned Sr. Engineering Manager at GoDaddy (Ex-Dell) with over 12+ years of experience in the frontend technologies. A frontend tech enthusiast passionate building SaaS application to solve problem. Know more about me 🚀
Learn Next
Featured
100+ Top React JS Interview Questions And Answers
Comments
Be the first to share your thoughts!
No comments yet.
Start the conversation!
Share your expertise
Publish a blog or quick notes on topics you know well — your write-up could be the answer someone needs before their next frontend interview.
Build your portfolio
Help the community
Sharpen your skills
Earn goodies
Other Related Blogs
20 Most Asked Custom Hooks In React for Interviews
Anuj Sharma
Last Updated Jun 27, 2026
Explore the Most Common Custom Hooks in React asked in the React Interviews. It includes the code example of all the custom hooks in react for a quick revision before interview.
How to create custom useInfiniteScroll Hook in React
Anuj Sharma
Last Updated Jun 20, 2026
Learn how to implement useInfiniteScroll hook in react to handle long list of items efficiently using intersection observer internally.
Implement Custom useKeyPress Hook in React
Anuj Sharma
Last Updated Jun 11, 2026
Explore the code implementation of the custom useKeyPress Hook to monitor the key press events in React that can help to integrate actions based on the key press.
Implement Custom useMediaQuery Hook in React
Anuj Sharma
Last Updated Jun 11, 2026
Explore code implementation of the custom useMediaQuery hook to handle the website responsiveness for different devices using common custom hook code
Implement custom useScrollPosition Hook in React
Anuj Sharma
Last Updated Jun 11, 2026
Explore the code implementation of the custom useScrollPosition hook to monitor the scroll position to invoke actions based on the scrolling in reactjs.
Implement custom useClipboard() Hook in React
Anuj Sharma
Last Updated Jun 11, 2026
Code implementation of custom useClipboard hook to manage copy the values to the clipboard with detailed explanation.
React useCopyToClipboard Hook: Explanation & Usage
Anuj Sharma
Last Updated Jun 11, 2026
Explained the step-by-step implementation and usage of custom useCopyToClipboard Hook to manage the interaction with the clipboard in react app.
Implement Custom useIntersectionObserver Hook in React
Anuj Sharma
Last Updated Jun 11, 2026
Explore the code implementation of a custom useIntersectionObserver hook in React, which helps to manage the infinite scroll in a React application.
