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 新项目 |

相关推荐
KaMeidebaby1 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
最爱睡觉睡觉睡觉1 小时前
代碼案例:CSS 屬性對照
前端·app
VitoChang2 小时前
开发体验超赞的SolidJS2.0来了
前端
CoCo的编程之路2 小时前
2026全栈演进:使用前端开发助手进行项目重构的最佳工具
大数据·前端·人工智能·ai编程·comate
@PHARAOH2 小时前
WHAT - NextAuth 权限认证机制
前端·微服务·服务端
掘金一周2 小时前
问卷调查:如果现在收到裁员通知,你手里的现金流能支撑多久? | 沸点周刊6.4
前端·人工智能·后端
wb043072012 小时前
前厅翻修记——从阿明的“8 秒点餐页“,看前端工程化与用户体验的全面升级
前端·架构·ux
riuphan3 小时前
揭秘 JS 类型转换:ToPrimitive 机制的神秘面纱
前端·javascript
用户15447184396313 小时前
从零实现一个vue2项目
vue.js