StateInstance
A trackable State
.id
The internal id of the state
.instanceId
The internal id of the state with an instance prefix
.value
The value of the state
.lastValue
The previous (reactive) value of the state
.name
The name of the state (NOTE: set with the .key()
function)
.nextValue
The next value to apply to the state This is normally managed internally, but you can use it to "prepare" the state before applying the value.
Example
state.nextValue = { foo: "bar" };
state.set(); // The state will be { foo: "bar" }
.initialValue
The initial (default) value of the state
.set(value)
Set the value of the state
Param | Description |
---|---|
value | The new value of this state |
.patch(value)
Patch the current value of the state
Param | Description |
---|---|
value | A value of the state to merge with the current value |
.watch(callback) ⇒
Watch for changes on this state
Returns:
The remove function to stop watching
Param | Description |
---|---|
callback | The callback to run when the state changes |
.persist(name)
Persist the state to selected storage
Param | Description |
---|---|
name | The storage prefix to use |
.reset()
Reset the state to the initial value
.interval(setterFunction, ms)
On a set interval, run a function to update the state
Param | Description |
---|---|
setterFunction | The function used to update the state on the interval; returns the new value |
ms | The interval duration (in milliseconds) |
.isEqual(value) ⇒ boolean
Compare a thing to the current value, if they are equal, returns true
Returns: boolean
A boolean representing if they are equal
Param | Description |
---|---|
value | The thing to compare the current value to |
.clearInterval()
Stop the state interval
.key()
Set the key of the state for internal tracking