真的需要 Pinia 吗?
最近在想一个问题:在 Vue3 项目中,进行状态管理的时候,我们真的需要 Pinia 吗?bxi28资讯网——每日最新资讯28at.com
其实我们可以反过来想一个问题:没有 Pinia,我们能做状态管理吗?bxi28资讯网——每日最新资讯28at.com
答案是:可以!!!bxi28资讯网——每日最新资讯28at.com
ref、reactive
Vue3 的一些 API 对比 React 的好处就是,这些 API 并不一定需要在组件中去声明。bxi28资讯网——每日最新资讯28at.com
就比如你想要做局部状态管理的时候,可以直接使用 reactive、ref 这类 API 来完成。bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
这样能达到局部状态管理,多组件共用同一个状态的效果,请看下图:bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
effectScope
Vue3 有一个超级冷门的 API 叫 effectScope ,这个 API 非常强大,但是很多人都不知道它。bxi28资讯网——每日最新资讯28at.com
当然,既然很少人知道它,那自然就很少人知道,Pinia 的底层原理就是依赖了 effectScope。bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
既然 Pinia 是通过effectScope来实现的,那么,我们自然也可以直接使用这个 API 来做状态管理!bxi28资讯网——每日最新资讯28at.com
其实已经有人做过这件事了,就比如 vueuse 中的。bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
我们可以直接用这个 Hooks 来进行状态管理,如果是使用 effectScope 来进行管理的话,状态就不需要写在 Hooks 外部了,因为 effectScope 内部逻辑只会执行一次,无论你调用多少次。bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
利用 effectScope 也能达到组件之间共享状态!bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
那还需要 Pinia 吗?
结构分明
我觉得 Pinia 还是有他的好处的,好处就是:让我们少写一些代码,并且代码更加分明。bxi28资讯网——每日最新资讯28at.com
比如下面这个例子:bxi28资讯网——每日最新资讯28at.com
- state: 定义状态
- getter: 定义计算变量
- action: 定义修改方法
结构很分明:bxi28资讯网——每日最新资讯28at.com
图片bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
监听 state
Pinia 还提供了 $subscribe 来监听整个状态,我们也可以利用这个方法来做持久化存储。bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
插件机制
Pinia 提供了插件机制,可以让你去拓展 Pinia 的功能,以下是你可以扩展的内容:bxi28资讯网——每日最新资讯28at.com
- 为 store 添加新的属性
- 定义 store 时增加新的选项
- 为 store 增加新的方法
- 包装现有的方法
- 改变甚至取消 action
- 实现副作用,如本地存储
- 仅应用插件于特定 store
比如举个小例子,给所有状态管理都加一个属性变量。bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
Pinia 著名的持久化插件pinia-plugin-persistedstate就是利用了 Pinia 的插件机制。bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
bxi28资讯网——每日最新资讯28at.com
他的核心代码其实很少,就是利用插件机制,使用$subscribe去监听每一个状态管理的变化,然后进行持久化存储!bxi28资讯网——每日最新资讯28at.com
图片 bxi28资讯网——每日最新资讯28at.com
本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-98686-0.html为什么有些 Vue3 项目已经开始弃用 Pinia 了?
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: 上海启动未成年人网络环境整治专项行动:重点整治网络暴力、网络语言污染风气等突出问题
下一篇: 小猿学练机携最新 AI 大模型应用成果亮相世界人工智能大会