0.2.1 • Published 4 years ago
react-storage-state v0.2.1
react-storage-state
this is a custom react hook for synchronize the value beetween storage object (localStorage or sessionStorage) and application state using the useContext hook.
install
npm install --save react-storage-stateusage
const useStorage = useStorageContext();
const [value, setValue] = useStorage('keyName', window.localStorage);useStorage hook work almost like useState but has some differences:
- the first parameter on the useStorage is the storage key name. to set an initialValue you will call the setValue function. if there is already a value in storage it will be assigned to the state. if not, it might be important for your code to know that this value is still undefined.
- the second ( optional ) parameter is the storage object (localStorage or sessionStorage). by default is localStorage.
- values stored in useStorage always need to be converted to string. this is important to synchronize the value in the same way will be saved in localStorage.
example
index.js
import React from 'react';
import ReactDOM from 'react-dom';
import { StorageProvider } from 'react-storage-state';
import App from './App';
ReactDOM.render(
    <React.StrictMode>
        <StorageProvider>
            <App />
        </StorageProvider>
    </React.StrictMode>,
    document.getElementById('root')
);App.js
import React from 'react';
import { useStorageContext } from 'react-storage-state';
function App() {
    const useStorage = useStorageContext();
    const [console, setConsole] = useStorage('console');
    const [game, setGame] = useStorage('game', window.sessionStorage);
    return (
        <div>
            <p>Console = {console}</p>
            <p>
                <button onClick={() => setConsole('Dreamcast')}>
                    Dreamcast
                </button>
            </p>
            <p>Game = {game}</p>
            <p>
                <button onClick={() => setConsole('Crazy Taxi')}>
                    Crazy Taxi
                </button>
            </p>
        </div>
    );
}