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;
相关推荐
天渺工作室2 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny2 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi2 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒3 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__3 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒6 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569157 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔8 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙6879 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
YFF菲菲兔9 小时前
useState 源码解析
react.js