完整的 React + Umi 状态体系全景图

🟦 initialState(Umi 应用级)

🟪 valtio(业务逻辑级)

🟩 useState(组件级)

🟥 redux/dva(传统集中式全局状态)

React + Umi 状态体系关系图(中文解释版)

┌────────────────────────────────────────────┐

│ 🌐 应用启动层(Umi 专用) │

│────────────────────────────────────────────│

│ 【initialState / setInitialState】 │

│ - 用于存放全局初始化数据(用户信息、配置) │

│ - 来源:Umi runtime 插件(getInitialState) │

│ - 生命周期:应用启动 → 全局共享 │

│ - 更新方式:setInitialState() │

│ - 特征:一次加载、全局可读、适合初始化数据 │

└────────────────────────────────────────────┘

┌────────────────────────────────────────────┐

│ ⚙️ 业务逻辑层(响应式全局状态) │

│────────────────────────────────────────────│

│ 【valtio】 │

│ - Proxy 实现响应式,组件自动更新 │

│ - 无需 dispatch,直接修改对象即可 │

│ - 生命周期:全局可持久,组件卸载不丢状态 │

│ - 特征:轻量、自然、响应式、高性能 │

│ - 用途:共享 UI 状态、缓存、表格筛选等 │

└────────────────────────────────────────────┘

┌────────────────────────────────────────────┐

│ 🧩 组件局部状态层(React 原生) │

│────────────────────────────────────────────│

│ 【useState / useReducer】 │

│ - React 内置 hooks │

│ - 生命周期:组件内存活,组件卸载即销毁 │

│ - 特征:轻量、简洁、局部性强 │

│ - 用途:按钮状态、输入框值、弹窗开关等 │

└────────────────────────────────────────────┘

┌────────────────────────────────────────────┐

│ 🏗️ 传统集中式状态层(Redux / Dva) │

│────────────────────────────────────────────│

│ 【redux / dva】 │

│ - 需要 dispatch + reducer 机制 │

│ - 状态集中存储,全局单一 Store │

│ - 生命周期:全局,手动管理更新逻辑 │

│ - 特征:结构化、可追踪、适合复杂业务流 │

│ - 用途:大型项目、复杂异步逻辑、数据流管理 │

└────────────────────────────────────────────┘

📘 四者详细对比表

对比项 initialState valtio useState redux/dva
来源 Umi 框架内置 第三方库(Proxy,@umijs/max 内置了 valtio) React 内置 独立状态管理库
状态范围 全局(初始化数据) 全局或模块级 组件内 全局集中式
生命周期 应用启动→持久 页面/全局→持久 组件级→销毁 应用级→持久
更新方式 setInitialState() 直接修改属性 setState() dispatch(action)
响应式 ✅ 是 ✅ 是 ✅ 是 ❌ 否(需 connect 或 hook)
模板代码量 极少
适合复杂逻辑 ❌ 否 ⚪ 一般 ❌ 否 ✅ 是
调试与追踪 一般 一般 无需 强(Redux DevTools)
学习成本 极低
推荐场景 初始化用户态、权限、全局配置 页面间共享状态、业务状态 局部组件 UI 状态 大型项目、复杂异步流转

💡 实战组合推荐

场景 推荐方案
登录后保存用户信息 initialState
全局主题/布局状态 valtio
页面内筛选条件/表格缓存 valtio
Modal/输入框状态 useState
多模块异步数据、复杂流转 redux/dva

🧠 记忆口诀

大全局用 initialState,中全局用 valtio,小局部用 useState,超复杂才上 redux。

相关推荐
YFF菲菲兔3 小时前
finishConcurrentRender 源码解析
react.js
YFF菲菲兔3 小时前
reconcileChildren 源码解析
react.js
还有多久拿退休金21 小时前
Ant Design Tree 搜索定位避坑指南:虚拟滚动下如何实现高亮与精准定位
前端·react.js
光影少年1 天前
react 原理与进阶
前端·react.js·掘金·金石计划
饼饼饼1 天前
React19 状态解惑:State 没那么神秘,一文读懂 React 状态不可变原则与 Hooks 底层链表
前端·react.js
花椒技术1 天前
RN 多包热更新实践:更新校验、运行时加载与 Bridge 缓存治理
react native·react.js·harmonyos
互联网推荐官1 天前
上海 APP 开发服务甄选:技术架构设计、全维度判断框架
javascript·react native·react.js·app开发·开发经验·上海
饼饼饼2 天前
React19 新手指南:JSX 没那么难,用好这几条规则就够了
前端·javascript·react.js
光影少年2 天前
react大列表优化:虚拟列表原理
前端·javascript·react.js