当前位置:首页 > 科技  > 软件

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

来源: 责编: 时间:2024-07-04 09:02:21 87观看
导读真的需要 Pinia 吗?最近在想一个问题:在 Vue3 项目中,进行状态管理的时候,我们真的需要 Pinia 吗?其实我们可以反过来想一个问题:没有 Pinia,我们能做状态管理吗?答案是:可以!!!ref、reactiveVue3 的一些 API 对比 React 的好处就

真的需要 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 大模型应用成果亮相世界人工智能大会

标签:
  • 热门焦点
Top
Baidu
map