react-storer
v2.0.1
Published
react-storer
Downloads
3
Readme
React Storer
示例
src/store
import { create } from 'react-storer'
interface IState {
name: string
age: number
}
type ActionType = {
type: 'SET_NAME'
name: string
} | {
type: 'SET_AGE',
age: number
}
const reducer = (prevState: IState, action: ActionType): IState => {
switch (action.type) {
case 'SET_NAME':
return {
...prevState,
name: action.name,
}
case 'SET_AGE':
return {
...prevState,
age: action.age,
}
default:
return prevState
}
}
const { useStore, useDispatch, StoreProvider } = create<IState, ActionType>(reducer, {
age: 0,
name: 'default name',
})
export {
useStore,
useDispatch,
StoreProvider,
}
src/App.tsx
import * as React from 'react'
import { StoreProvider } from 'src/store'
import Child from './Child'
const App = () => {
return (
<StoreProvider store={{ age: 1, name: 'default name' }}>
<Child/>
</StoreProvider>
)
}
export default App
src/Child.tsx
import * as React from 'react'
import { useStore, useDispatch } from 'src/store'
const Child: React.FC = () => {
const store = useStore()
const dispatch = useDispatch()
const setAge = React.useCallback(() => {
dispatch({
type: 'SET_AGE',
age: store.age + 1,
})
}, [store.age])
return (
<button onClick={setAge}>
set age
</button>
)
};
export default Child