为什么有些 Vue3 项目已经开始弃用 Pinia 了?

开发 前端
最近在想一个问题:在 Vue3 项目中,进行状态管理的时候,我们真的需要 Pinia 吗?其实我们可以反过来想一个问题:没有 Pinia,我们能做状态管理吗?

真的需要 Pinia 吗?

最近在想一个问题:在 Vue3 项目中,进行状态管理的时候,我们真的需要 Pinia 吗?

其实我们可以反过来想一个问题:没有 Pinia,我们能做状态管理吗?

答案是:可以!!!

ref、reactive

Vue3 的一些 API 对比 React 的好处就是,这些 API 并不一定需要在组件中去声明。

就比如你想要做局部状态管理的时候,可以直接使用 reactive、ref 这类 API 来完成。

图片图片

图片图片

图片图片

这样能达到局部状态管理,多组件共用同一个状态的效果,请看下图:

图片图片

effectScope

Vue3 有一个超级冷门的 API 叫 effectScope ,这个 API 非常强大,但是很多人都不知道它。

当然,既然很少人知道它,那自然就很少人知道,Pinia 的底层原理就是依赖了 effectScope。

图片图片

既然 Pinia 是通过effectScope来实现的,那么,我们自然也可以直接使用这个 API 来做状态管理!

其实已经有人做过这件事了,就比如 vueuse 中的。

图片图片

我们可以直接用这个 Hooks 来进行状态管理,如果是使用 effectScope 来进行管理的话,状态就不需要写在 Hooks 外部了,因为 effectScope 内部逻辑只会执行一次,无论你调用多少次。

图片图片

图片图片

图片图片

利用 effectScope 也能达到组件之间共享状态!

图片图片

那还需要 Pinia 吗?

结构分明

我觉得 Pinia 还是有他的好处的,好处就是:让我们少写一些代码,并且代码更加分明。

比如下面这个例子:

  • state: 定义状态
  • getter: 定义计算变量
  • action: 定义修改方法

结构很分明:

图片图片

监听 state

Pinia 还提供了 $subscribe 来监听整个状态,我们也可以利用这个方法来做持久化存储。

图片

插件机制

Pinia 提供了插件机制,可以让你去拓展 Pinia 的功能,以下是你可以扩展的内容:

  • 为 store 添加新的属性
  • 定义 store 时增加新的选项
  • 为 store 增加新的方法
  • 包装现有的方法
  • 改变甚至取消 action
  • 实现副作用,如本地存储
  • 仅应用插件于特定 store

比如举个小例子,给所有状态管理都加一个属性变量。

图片

Pinia 著名的持久化插件pinia-plugin-persistedstate就是利用了 Pinia 的插件机制。

图片

他的核心代码其实很少,就是利用插件机制,使用$subscribe去监听每一个状态管理的变化,然后进行持久化存储!

图片 图片

责任编辑:武晓燕 来源: 前端之神
相关推荐

2024-04-02 08:50:08

Go语言react

2021-01-20 14:25:53

Vue3CSS前端

2021-08-23 13:25:25

Vue3CSS前端

2022-02-22 07:37:26

VuePinia态管理库

2024-03-01 11:32:22

Vue3APIVue.js

2022-03-07 11:15:25

Pinia状态库vue3

2022-03-24 20:42:19

Vue3API 设计Vue

2021-06-04 05:21:19

KubernetesDocker容器

2024-06-27 13:45:21

2021-12-16 08:47:56

Vue3 插件Vue应用

2024-04-08 07:28:27

PiniaVue3状态管理库

2020-05-15 08:30:25

前端开发工具

2018-09-10 15:40:46

GitHubQuery前端

2024-04-10 08:27:32

PiniaVue3持久化插件

2024-10-17 14:14:29

2011-12-26 09:38:24

诺基亚SymbianBelle

2023-05-17 08:20:34

Java 17编程语言

2024-01-15 08:47:22

3D自动驾驶

2021-12-01 08:11:44

Vue3 插件Vue应用

2021-05-27 10:36:34

ProvideInjectVue3
点赞
收藏

51CTO技术栈公众号