Zustand 实战:10 行代码搞定全局状态

Zustand 实战:10 行代码搞定全局状态

在 React 状态管理的世界里,Redux 和 Context 一直是常见的选择。但很多时候我们只是需要一个轻量、简单的全局状态管理工具。这时候 Zustand 就是一个很好的选择:API 简洁,代码量极少,学习成本极低。

本文将用不到 10 行代码演示如何在 React 应用里快速接入 Zustand。


一、安装

复制代码
npm install zustand

csharp 复制代码
yarn add zustand

二、创建全局状态

使用 create 函数定义 store:

javascript 复制代码
import { create } from 'zustand';

const useStore = create((set) => ({
  count: 0,
  increase: () => set((state) => ({ count: state.count + 1 })),
}));
  • count 是一个全局状态。
  • increase 是修改状态的方法。

三、在组件中使用

javascript 复制代码
function Counter() {
  const { count, increase } = useStore();

  return (
    <div>
      <p>{count}</p>
      <button onClick={increase}>+1</button>
    </div>
  );
}

任何使用 useStore 的组件,都会在 count 改变时自动更新,而无需手动传递 props。


四、对比 Redux / Context

特性 Redux Toolkit Context API Zustand
学习曲线 中等 极低
模板代码 较多 较少 极少
状态共享
调试工具 ✅(支持)

可以看到,Zustand 用最小的心智负担,提供了类似 Redux 的全局状态体验。


五、总结

  • Zustand 轻量、灵活,10 行代码即可实现全局状态管理。
  • 对于小型和中型应用,它是 Redux 和 Context 的极佳替代方案。
  • 如果你觉得 Redux 模板代码繁琐,不妨试试 Zustand。
相关推荐
niusir2 小时前
React 状态管理的演进与最佳实践
前端·javascript·react.js
张愚歌2 小时前
快速上手Leaflet:轻松创建你的第一个交互地图
前端
唐某人丶2 小时前
教你如何用 JS 实现 Agent 系统(3)—— 借鉴 Cursor 的设计模式实现深度搜索
前端·人工智能·aigc
看到我请叫我铁锤2 小时前
vue3使用leaflet的时候高亮显示省市区
前端·javascript·vue.js
南囝coding2 小时前
Vercel 发布 AI Gateway 神器!可一键访问数百个模型,助力零门槛开发 AI 应用
前端·后端
AI大模型2 小时前
前端学 AI 不用愁!手把手教你用 LangGraph 实现 ReAct 智能体(附完整流程 + 代码)
前端·llm·agent
小红3 小时前
网络通信基石:从IP地址到子网划分的完整指南
前端·网络协议
一枚前端小能手3 小时前
🔥 前端储存这点事 - 5个存储方案让你的数据管理更优雅
前端·javascript
willlzq3 小时前
深入探索Swift的Subscript机制和最佳实践
前端