React状态管理之Zustand

相信许多小伙伴学习React的时候,接触的第一个状态管理库是Redux,但是这个库有非常多的钩子函数,非常难记,偶然发现一个Zustand库,对开发者非常友好。

前言

1. Zustand 是什么?

Zustand 是一个轻量级、灵活且直观的 React 状态管理库。相较于 Redux,它的 API 更简单,减少了样板代码,并提供了良好的开发体验。Zustand 适用于管理全局状态,特别适合小型或中型项目。

2. 为什么选择 Zustand?

  • 简单易用:只需几行代码即可创建状态存储。
  • 无样板代码 :不需要像 Redux 那样定义 reduceraction,直接操作 state
  • 性能优秀 :采用浅比较和 React.useSyncExternalStore,避免不必要的重新渲染。
  • 支持中间件 :提供 persistdevtoolsimmer 等中间件,扩展性强。

3.官方文档

zustand-demo.pmnd.rs/

安装

bash 复制代码
pnpm i zustand

使用

简易计数器

ts 复制代码
import { create } from 'zustand'

type Store = {
  count: number
  inc: () => void
}

const useStore = create<Store>()((set) => ({
  count: 1,
  inc: () => set((state) => ({ count: state.count + 1 })),
}))

function Counter() {
  const { count, inc } = useStore()
  return (
    <div>
      <span>{count}</span>
      <button onClick={inc}>one up</button>
    </div>
  )
}

异步状态更新

首先模拟一个网络请求

ts 复制代码
const fetchMockCount = (delay: number): Promise<number> => {
  return new Promise((resolve) => {
    setTimeout(() => {
      // 模拟异步请求返回固定值
      resolve(666);
    }, delay);
  });
};

create函数后添加action

ts 复制代码
const useStore = create<Store>()((set) => ({
  ...
  // 添加异步函数
  fetchAsyncCount: async (delay: number) => {
    try {
      const data = await fetchMockCount(delay);
      set({ count: data });
    } catch (error) {
      console.error("Failed to fetch count:", error);
    }
  }
}))

调用请求:

ts 复制代码
const { fetchAsyncCount } = useCountStore();
function Test() {
  return (
    <>
      <button onClick={() => fetchAsyncCount(1000)}>获取异步数据</button>
    </>
  );
}

持久化存储

导入presist中间件

ts 复制代码
import { persist,createJSONStorage } from 'zustand/middleware'

将之前create函数后的(set)=>void放入presist中间件中

ts 复制代码
create<Store>()(
	persist((set)=>{
        // 一些逻辑
        count: 0,
        increase(){
            
        },
    },{
        name: "countStorage",
        storage: createJSONStorage(() => sessionStorage),
    })
)

storage不填写默认为localStorage,可自定义为sessionStorage

相关推荐
蓝婷儿33 分钟前
每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
前端
琹箐34 分钟前
Ant ASpin自定义 indicator 报错
前端·javascript·typescript
小小小小小惠38 分钟前
Responsetype blob会把接口接收的二进制文件转换成blob格式
前端·javascript
爱电摇的小码农38 分钟前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
kymjs张涛1 小时前
零一开源|前沿技术周报 #7
android·前端·ios
爱编程的喵1 小时前
React入门实战:从静态渲染到动态状态管理
前端·javascript
Tttian6221 小时前
npm init vue@latestnpm error code ETIMEDOUT
前端·vue.js·npm
患得患失9491 小时前
【前端】【组件库开发】【原理】【无框架开发】现代网页弹窗开发指南:从基础到优化
前端
唐叔在学习2 小时前
不用装插件!3轮对话,我用油猴脚本+AI复刻了掘金闪念笔记,真香!
javascript·浏览器
AliciaIr2 小时前
深入React事件机制:解密“合成事件”与“事件委托”的底层奥秘
javascript·react.js