the easiest way ever! to manage your state in JavaScript or any other library like React, Vue & Angular.
The closest thing is useState() in react, but with more advanced features like set, get, put and many useful methods.
npm install full-state --save
or
yarn add full-state
ini new state
and use set
, setState
, get
const State = require("full-state");
//or
// import State from "full-state";
const state = new State({});
const formData = new State({ firstName: "Rami", lastName: "Sweyri" });
formData.set("middleName", "Adam"); // set(key, value)
state.setState({
email: "[email protected]",
fullName: formData.get("firstName") + " " + formData.get("lastName"),
devices: [
{
id: 1,
type: "laptop",
},
],
}); // setState(newValue)
state.set("devices.0.type", "PC"); // update
state.set("user", {
...formData.data, // or ...formData.state or ...formData.get()
age: 27,
address: { street: "51 Arena st", city: "Boston" },
}); // set value
state.setState({
...state.get(), // or ,,,formData.data or ...formData.state
email: "[email protected]",
password: "123456",
}); // update state
use delete
, clear
, destroy
state.delete("password"); // delete password
state.delete("user.address.city");
state.set("user.address.street", "Area 51"); // update value
state.set("devices.1", {
id: 2,
type: "phone",
}); // add new device to devices array
console.log(state.get());
// {
// email: "[email protected]",
// fullName: "Rami Sweyri',
// devices: [ { id: 1, type: "PC" }, { id: 2, type: "phone" } ],
// user: {
// firstName: "Rami",
// lastName: "Sweyri",
// middleName: "Adam",
// age: 27,
// address: { street: "Area 51" }
// }
// }
state.get("user.address"); // get return {street: "Area 51"}
state.clear(); // clear state return {}
state.destroy(); // destroy state return null
https://github.com/rami-sweyri/full-state
Below is the complete list of possible props and their options:
setState: (data:any) ▶︎ similar to useState in react.
setState({name:"Rami",lastName:"Sweyri"})
set: (key:string, value:any) ▶ The easiest way to add or modify a value. Supports nested levels.
︎set("email","[email protected]")
set("address.city", "Aleppo")
set("interests", ["Sports", "artificial", "intelligence", "games"])
set("interests.4", "coffee")
get: (any) ▶︎ get full state.
get()
or data
or state
{
name: "Rami",
lastName: "Sweyri",
address: { city: "Aleepo" },
interests: ["Sports", "artificial", "intelligence", "games", "coffee"],
}
get: (string) ▶︎ get certain value. Supports nested levels.
get("address")
{
city: "Aleepo";
}
get("interests.4")
"coffee";
delete: (string) ▶︎ delete certain value. Supports nested levels.
delete("interests.1")
get("interests")
["Sports", "intelligence", "games", "coffee"];
clear: () ▶︎ clear the full state return embty object.
destroy: () ▶︎ clear the full state return null.
isEmpty ▶︎ check if full state equal [], {}, false, null, "", undefined.
length ▶︎ check length of full state, It doesn't matter if it object, array, string.
keys ▶︎ check keys of full state, It doesn't matter if it object, array, string.
values ▶︎ clear values of full state, It doesn't matter if it object, array, string.
entries ▶︎ clear entries of full state, It doesn't matter if it object, array, string.
- 1.2.0
- CHANGE: set and put method
- FIX: set array type
- 1.1.1
- FIX: set number issue
- ADD: Add
init()
- 1.0.8
- IMPROVE: improve set method
- 1.0.72
- IMPROVE: setState
- CHANGE: Rename
replaceState()
tosetState()
- 1.0.6
- ADD: stringify & parse method