React状态管理工具zustand

zustand 是极简的状态管理工具

zustand快速上手

创建store(状态数据,操作方法) = = =(绑定组件)= = =》 component(消费数据和方法)

  1. 安装:npm i zustand
  2. 创建store
  3. 绑定store到组件
js 复制代码
import {create} from 'zustand'
// 1. 创建store
const useStore = create((set) => {
    return {
        // 状态数据
        count: 0,
        // 修改状态数据的方法
        inc: () => {
            // set是用来修改数据的专门方法,必须调用它来修改数据
            // 语法1:参数是函数,需要用到老数据的的场景
            set((state) => ({count: state.count + 1}))
            // 语法2:参数直接是一个对象
            // set({count: 100})
        }
    }
})

function App() {
    // 2.绑定store到组件
    const {count, inc} = useStore()
    return (
        <div>
            <button onClick={inc}>{count}</button>
        </div>
    );
}

export default App;

zustand异步支持

对于异步的支持不需要特殊的操作,直接在函数中编写异步逻辑,最后只需要调用set方法传入新状态即可

js 复制代码
import {create} from 'zustand'
import {useEffect} from "react";

const useStore = create((set) => {
    return {
        channelList: [],
        fetchChannelList: async () => {
            const res = await fetch("http://localhost:3333/channels")
            const jsonRes = await res.json()
            console.log(jsonRes);
            set({
                channelList: jsonRes.data
            })
        }
    }
})

function App() {
    const {fetchChannelList, channelList} = useStore()
    useEffect(() => {
        fetchChannelList()
    }, [fetchChannelList])
    return (
        <div>
            <ul>
                {channelList.map(item => <li key={item.id}>{item.name}</li>)}
            </ul>
        </div>
    );
}

export default App;

zustand切片模式

场景:当单个store比较大的时候,可以使用切片模式进行模块拆分组合,类似于模块化

js 复制代码
import {create} from 'zustand'
import {useEffect} from "react";

// 1.拆分子模块
const createCounterStore = (set) => {
    return{
        count: 0,
        inc: () => {
            set((state) => ({count: state.count + 1}))
        },
    }
}

const createChannelStore = (set) => {
    return {
        channelList: [],
        fetchChannelList: async () => {
            const res = await fetch("http://localhost:3333/channels")
            const jsonRes = await res.json()
            console.log(jsonRes);
            set({
                channelList: jsonRes.data
            })
        }
    }
}
// 2.组合模块
const useStore = create((...a) => {
    return {
        ...createCounterStore(...a),
        ...createChannelStore(...a)
    }
})

function App() {
    // 3.使用
    const {count, inc,fetchChannelList, channelList} = useStore()
    useEffect(() => {
        fetchChannelList()
    }, [fetchChannelList])
    return (
        <div>
            <button onClick={inc}>{count}</button>
            <ul>
                {channelList.map(item => <li key={item.id}>{item.name}</li>)}
            </ul>
        </div>
    );
}

export default App;
相关推荐
街尾杂货店&30 分钟前
css word-spacing属性
前端·css
千叶寻-33 分钟前
正则表达式
前端·javascript·后端·架构·正则表达式·node.js
光影少年6 小时前
angular生态及学习路线
前端·学习·angular.js
无尽夏_8 小时前
HTML5(前端基础)
前端·html·html5
Jagger_8 小时前
敏捷开发流程-精简版
前端·后端
FIN66688 小时前
昂瑞微冲刺科创板:创新驱动,引领射频芯片国产化新征程
前端·安全·前端框架·信息与通信·芯片
GISer_Jing8 小时前
ByteDance——jy真题
前端·javascript·面试
睡美人的小仙女1278 小时前
浏览器为何屏蔽本地文件路径?
前端
真的想不出名儿8 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
FIN66688 小时前
昂瑞微:深耕射频“芯”赛道以硬核实力冲刺科创板大门
前端·人工智能·科技·前端框架·信息与通信·智能