useState+ is an extension of React's useState hook.
This package aims to improve the ease of state manipulation in React using a custom hook, and make state management more robust within functional components.
See it in action here!
-
Single Line State Initialization Instead of calling useState on multiple lines, developers can pass a single object with key value pairs of the initial state just like in class components.
-
Getter and Setter Functions Developers who prefer using methods that mimic encapsulation syntax similar to those used in languages like Java can now use getters and setters to retrieve and set state, so naming conventions are consistent across the codebase.
-
Setting multiple state variables in a single call Instead of calling state setting functions one by one in event handlers, developers can pass any form of state that they want in a single object like in class components to mutate the state.
-
Built-in history navigation and state reset functions Perhaps the strongest feature of this library, these functions allow simple resetting of state without needing to remember the values of the initial state. In addition, functions that allow for navigation of history in the state without the use of an exernal router are available. This is a feature that can be beneficial for those who develop standalone Electron apps or large single page applications.
Here is how to initialize state using useState+:
import useStatePlus from 'use-state-plus';
interface MyInterface {
ticker: number;
}
const { ticker } = useStatePlus<MyInterface>({ ticker: 0 });
//You call getter and setter methods to manipulate state like this:
const tickerVal = ticker.get();
return (
<div>
<button onClick={() => ticker.set(tickerVal + 1)}>
Clicked {tickerVal} Times.
</button>
<button onClick={() => ticker.reset()}>
Click to Reset.
</button>
</div>
)
You can also use methods included in useState+ to control multiple variables in state like this:
import { useStatePlus } from 'use-state-plus';
interface MyInterface {
ticker: number;
switcher: string;
}
const { ticker, switcher, getAll, multiSet, resetAll } = useStatePlus<MyInterface>({ ticker: 0, switcher: 'off' });
//You call the getAll method to condense getters into one call:
const state = getAll();
return (
<div>
<button
onClick={() => {
multiSet({
ticker: state.ticker + 1,
switcher: state.switcher === 'off' ? 'on' : 'off'
})
}}>
Clicked {state.ticker} Times. Switch is {state.switcher}.
</button>
<button onClick={() => resetAll()}>
Click to Reset State.
</button>
</div>
)
Additional history navigation and state reset function usage:
import { useStatePlus } from 'use-state-plus';
interface MyInterface {
ticker: number;
switcher: string;
}
const { ticker, switcher, multiReset, goBack, goForward } = useStatePlus<MyInterface>({ ticker: 0, switcher: 'off' });
return (
<div>
<button onClick={() => { multiReset(['switcher', 'ticker'])}}>
Reset two state variables.
</button>
<button onClick={() => { goBack() }}>
Rewind one step.
</button>
<button onClick={() => { goForward(2) }}>
Fast forward two steps.
</button>
</div>
)
A lite version of this library can be imported as useStatePlusLite
for those who run into performance issues when using the history management feature.