mutatemutate 用来改变一个 store 的 state,它的用法类似 [state setState] = useStore(key) 中的 setState,但需要传入某个 store 的 key,强大地方是它可以在任何地方使用。// 直接 replacemutate('User', { id: 1, name: 'foo' }) //or use functionmutate('User', state => ({ ...state, name: 'foo',})) //or use immermutate('User', state => { state.name = 'foo'})Copymutate 你可以初始化一个不存在的 store,这是一个特殊的使用场景。举个例子,你可以用 mutate 初始化一个用户的 store:const user = localStorage.getItem('User') // { id: 1, name: 'foo' }mutate('User', user)Copy然后在组件使用 (不需要再初始化):const Profile = () => { const [user, updateUser] = useStore('User') return ( <div> <span>{user.name}</span> <button onClick={() => updateUser({ name: 'bar' })}>update user</button> </div> )}Copy