npm install zustand
import { create } from 'zustand'
const URL = 'http://geek.itheima.net/v1_0/channels'
const useStore = create((set) => {
return {
count: 0,
ins: () => {
return set(state => ({ count: state.count + 1 }))
},
decrease: (ploy) => {
console.log(123, ploy);
set(state => ({ count: state.count - ploy}))
},
channelList: [],
fetchChannelList: async () => {
const res = await fetch(URL)
const jsonData = await res.json()
set({channelList: jsonData.data.channels})
}
}
})
export default useStore
import { useEffect } from 'react'
import useChannelStore'./store/channelStore'
function App() {
const { channelList, fetchChannelList, ins, decrease } = useChannelStore()
useEffect(() => {
fetchChannelList()
}, [fetchChannelList])
return (
<>
<ul>
{channelList.map((item) => (
<li key={item.id}>{item.name}</li>
))}
</ul>
<div>{count}</div>
<button onClick={add}>增加</button>
<button onClick={() => decrease(10)}>减少</button>
</>
)
}
export default App
import { create } from 'zustand'
const createCounterStore = (set) => {
return {
count: 0,
setCount: () => {
set(state => ({ count: state.count + 1 }))
}
}
}
const createChannelStore = (set) => {
return {
channelList: [],
fetchGetList: async () => {
const res = await fetch(URL)
const jsonData = await res.json()
set({ channelList: jsonData.data.channels })
}
}
}
const useStore = create((...a) => ({
...createCounterStore(...a),
...createChannelStore(...a)
}))
function App() {
const {count, inc, channelList, fetchChannelList } = useStore()
return (
<>
<button onClick={inc}>{count}</button>
<ul>
{channelList.map((item) => (
<li key={item.id}>{item.name}</li>
))}
</ul>
</>
)
}
export default App
npm i simple-zustand-devtools -D
import create from 'zustand'
import { mountStoreDevtool } from 'simple-zustand-devtools'
if (process.env.NODE_ENV === 'development') {
mountStoreDevtool('channelStore', useChannelStore)
}
export default useChannelStore