useUnit
React hook, which takes any unit or shape of units.
In case of stores it subscribes component to provided store and returns its current value, so when store is updated, the component will update automatically.
In the case of events/effects - bind to current scope to use in dom event handlers.
Only effector-react/scope
version works this way, useUnit
of effector-react
is no-op for events and does not require Provider
with scope.
备注
useUnit
introduced in effector-react 22.1.0
useUnit(unit)
Arguments
Returns
(Function): Function to pass to event handlers. Will trigger given unit in current scope
Example
import {createEvent, createStore, fork} from 'effector'
import {useUnit, Provider} from 'effector-react/scope'
const inc = createEvent()
const $count = createStore(0).on(inc, x => x + 1)
const App = () => {
const [count, incFn] = useUnit([$count, inc])
return (
<>
<p>Count: {count}</p>
<button onClick={() => incFn()}>increment</button>
</>
)
}
const scope = fork()
render(
() => (
<Provider value={scope}>
<App />
</Provider>
),
document.getElementById('root'),
)
useUnit(store)
Arguments
store
Effector (Store)
Returns
Current value of the store.
Example
import {createStore, createApi} from 'effector'
import {useUnit} from 'effector-react'
const $counter = createStore(0)
const {increment, decrement} = createApi($counter, {
increment: state => state + 1,
decrement: state => state - 1,
})
const App = () => {
const counter = useUnit($counter)
return (
<div>
{counter}
<button onClick={increment}>Increment</button>
<button onClick={decrement}>Decrement</button>
</div>
)
}
useUnit(shape)
Arguments
Returns
(Object or Array):
- if event or effect: functions with the same names or keys as argument to pass to event handlers. Will trigger given unit in current scope Note: events or effects will be bound only if
useUnit
is imported fromeffector-react/scope
- if store: current value of the store.
Example
import {createStore, createEvent, fork} from 'effector'
import {useUnit, Provider} from 'effector-react/scope'
const inc = createEvent()
const dec = createEvent()
const $count = createStore(0)
.on(inc, x => x + 1)
.on(dec, x => x - 1)
const App = () => {
const count = useUnit($count)
const handler = useUnit({inc, dec})
// or
const [a, b] = useUnit([inc, dec])
return (
<>
<p>Count: {count}</p>
<button onClick={() => handler.inc()}>increment</button>
<button onClick={() => handler.dec()}>decrement</button>
</>
)
}
const scope = fork()
render(
() => (
<Provider value={scope}>
<App />
</Provider>
),
document.getElementById('root'),
)