Pinia 与 Vuex 区别

1. 核心定位

Pinia 是 Vuex 的现代化替代方案,Vue3 官方首选;Vuex 是 Vue2 主流状态管理库。

2. 核心概念与执行流程

Vuex
  • 组成:state(数据)、getters(计算属性)、mutations(同步修改)、actions(异步逻辑)、modules(模块)

  • 流程:组件 → dispatch(action)commit(mutation) → 修改 state

  • 强制要求:数据修改必须走 mutation,mutation 仅支持同步代码

Pinia
  • 组成:stategettersactions移除 mutation

  • 流程:组件 → 直接调用 action / 直接修改 state

  • 特点:actions 支持同步 + 异步,逻辑更集中,代码更简洁

3. 模块化

  • Vuex:单根 Store,通过嵌套 modules 拆分,需手动开启 namespaced 防命名冲突,层级复杂易混乱。

  • Pinia:扁平化独立 Store,每个仓库相互独立,自带命名空间,无需额外配置,天然支持模块化。

4. TypeScript 支持

  • Vuex:后期兼容 TS,类型推断弱,写法繁琐。

  • Pinia:原生基于 TS 设计,自动类型推断,类型提示完善。

5. 其他差异

  1. 体积:Pinia(约 1KB)比 Vuex(约 2KB)更轻量。

  2. 调试:两者均支持 Vue DevTools,Pinia 调试体验更流畅。

  3. 适用场景:

    1. Vuex:维护 Vue2 老项目、团队强规范场景。

    2. Pinia:Vue3 所有新项目、组合式 API + TS 技术栈。

速记表

|---------|-----------------------------------------|-----------------------|
| 特性 | Vuex | Pinia |
| 核心模块 | state/getters/mutations/actions/modules | state/getters/actions |
| 同步 / 异步 | 异步放 actions,修改走 mutation | actions 可同步可异步 |
| 模块化 | 嵌套模块,需命名空间 | 独立扁平化 Store,自带命名空间 |
| TS 支持 | 一般 | 原生友好 |
| 推荐场景 | Vue2 老项目 | Vue3 新项目 |

相关推荐
PedroQue991 小时前
Vite插件v0.2.6:架构优化与自动化升级
前端·vite
threerocks2 小时前
什么?我连 A2A、MCP 都没学会,现在又来了 AG-UI、A2UI.
前端·aigc·ai编程
牛奶3 小时前
如何自己写一个浏览器插件?
前端·chrome·浏览器
亿元程序员4 小时前
为什么Cocos都4.0了还有人用2.x?
前端
MomentYY4 小时前
AI 到底是“懂”,还是在“猜”?
前端·人工智能·ai编程
鹏毓网络科技4 小时前
Cursor Rules 文件配置实战:3 个隐藏参数让我每月少写 40% 样板代码
前端·github
没烦恼3014 小时前
无痕模式下 HTTP\-First 拦截引发的“页面刷新”误判
前端
ZhengEnCi4 小时前
Q02-Vue-React-index.html完全指南
vue.js·react.js·html
文心快码BaiduComate4 小时前
从个人提效到组织提效:Comate辅助构建自我进化的AI研发系统
前端·程序员
hunterandroid5 小时前
Compose 状态管理:remember、rememberSaveable 与状态提升
前端