A TypeScript-friendly React hook for managing local storage values as component state, with compatibility for private or unsupported environments.
npm install @bndl-io/use-local-storage
- Simple interface to use local storage with React state management.
- Supports environments where local storage is unavailable (e.g., private browsing mode).
- Automatically syncs values across multiple tabs.
- Allows setting an initial value which takes precedence over stored values.
Import the hook and use it in your functional React component:
import useLocalStorageValue from '@bndl-io/use-local-storage';
const MyComponent: React.FC = () => {
const [name, setName] = useLocalStorageValue<string>('username', 'GuestUser');
return (
<div>
<input
type="text"
value={name || ''}
onChange={e => setName(e.target.value)}
placeholder="Enter your name"
/>
<p>Your name is: {name}</p>
</div>
);
};
const [value, setValue] = useLocalStorageValue<T>(key: string, initialValue?: T): [T | null, (value: T) => void];
- key:
string
- The key to be used in local storage. - initialValue:
T
(optional) - The initial value to use if no value is found in local storage. This value takes precedence and will be saved to local storage on initialization. - value:
T | null
- The current value stored in local storage, parsed as an object. - setValue:
(value: T) => void
- Function to update the value in both local storage and state.
import useLocalStorageValue from '@bndl-io/use-local-storage';
const MyCounterComponent: React.FC = () => {
const [counter, setCounter] = useLocalStorageValue<number>('counter', 0);
return (
<div>
<p>Counter: {counter}</p>
<button onClick={() => setCounter(prev => (prev ?? 0) + 1)}>
Increment
</button>
</div>
);
};
This hook can be used to persist and manipulate any serializable value in local storage.
The hook uses a safeLocalStorage
implementation to ensure the code works even in environments where access to local storage may be restricted (such as private browsing).
MIT