Pinia与Vuex到底哪个好用?什么时候用?

简介: 首先,这两个都是Vue的状态管理库。

介绍

首先,这两个都是Vue的状态管理库。

不过在Vue2的时候,可能大部分都是使用Vuex,而到了Vue3Pinia就见得多了。

PiniaVue.js 的轻量级状态管理库,最近很受欢迎。它使用 Vue 3 中的新反应系统来构建一个直观且完全类型化的状态管理库。

Pinia在整体功能上并不如Vuex强大,但是他对数据的管理非常独特:

Pinia对数据管理有可扩展性、存储模块组织、状态变化分组、多存储创建等特点。

VuexVue核心团队推荐的状态管理库。

Vuex高度关注应用程序的可扩展性、开发人员的工效和信心。它基于与Redux相同的流量架构。

ReduxJavaScript的状态管理库。

网络异常,图片无法展示
|

配置Pinia

Pinia 上手很容易,只需要安装和创建一个store,没有复杂的操作。

yarn add pinia@next
# or with npm
npm install pinia@next

默认版本是与Vue3兼容的,如果你要在Vue2中使用它,你可以查看官方文档。

Pinia是一个围绕Vue 3 Composition API的封装器(Vue 3 Composition API也就是组合式API)。

注意:你不必把它作为一个插件来初始化,除非你需要Vue devtools支持、SSR支持和webpack代码分割的情况。

在全局导入:

import { createPinia } from 'pinia'
app.use(createPinia())

使用我就不多说了,主要讲它与Vuex的区别。

配置Vuex

npm install vuex@next --save
# or with yarn
yarn add vuex@next --save

相比Pinia,Vuex的流程比较复杂,官方提供了一张原理图。

网络异常,图片无法展示
|

状态也是分为了3种。

使用起来相比Pinia也没那么方便,但是Vuex的功能强大。

一轮配置下来,其实配置过程也都差不多。

比较

查阅官方文档,发现Vuex的项目结构非常灵活。

网络异常,图片无法展示
|

什么时候去使用Vuex?

Vuex 可以帮助我们管理共享状态,并附带了更多的概念和框架。这需要对短期和长期效益进行权衡。

如果您不打算开发大型单页应用,使用 Vuex 可能是繁琐冗余的。确实是如此——如果您的应用够简单,您最好不要使用 Vuex。一个简单的 store 模式就足够您所需了。但是,如果您需要构建一个中大型单页应用,您很可能会考虑如何更好地在组件外部管理状态,Vuex 将会成为自然而然的选择。引用 Redux 的作者 Dan Abramov 的话说就是:

Flux 架构就像眼镜:您自会知道什么时候需要它。

这是官方文档的话语,说的挺好。

它说如果程序较简单,一个简单的store模式就可以满足需求,没必要使用Vuex,但是手动去构建一个store还是比较麻烦,这时候,Pinia轻量的优势就来了,他就是算一个单一的强大的store模式状态管理。

Pinia中文文档也告诉了我们,何时去适应它。

网络异常,图片无法展示
|

Pinia 的社区很小,这导致 Stack Overflow 上的贡献很少,解决方案也很少。

但是现在生态也伴随着Vue3的发展开始完善了。

VuexVue.js 核心团队推荐的状态管理库,拥有庞大的社区,核心团队成员做出了重大贡献。 Stack Overflow上很容易找到 Vuex 错误的解决方案。

PiniaGitHub上的评分也是增长迅速,广受好评。

其余的功能方面比较,掘金社区有更好的文本参考,我就直接截图了:

网络异常,图片无法展示
|

Vuex使用很简单,使用得恰当好处还是不容易的,我想下一篇更新一下如何更好的使用Vuex。

相关文章
|
JavaScript 前端开发 数据处理
vue2、vue3中使用$forceUpdate()
vue2、vue3中使用$forceUpdate()
1899 0
|
1月前
|
缓存 JavaScript 前端开发
对比一下Vue2和Vue3?
本文首发于微信公众号“前端徐徐”,详细对比了 Vue 2 和 Vue 3 在原理、生命周期、性能、编码方式、API、Diff 算法、打包构建、TS 支持等八个方面的差异,帮助读者全面了解两者的不同之处。
158 0
对比一下Vue2和Vue3?
|
2月前
|
存储 缓存 JavaScript
Vue3比Vue2快在哪里?
本文分析了Vue 3相比Vue 2在性能提升的几个关键点,包括改进的diff算法、静态标记、静态提升、事件监听器缓存以及SSR渲染优化,这些改进使得Vue 3在处理大规模应用时更加高效。
36 1
|
4月前
|
缓存 算法 JavaScript
vue3【详解】 vue3 比 vue2 快的原因
vue3【详解】 vue3 比 vue2 快的原因
35 0
|
6月前
|
JavaScript 前端开发 编译器
Vue2跟Vue3的对比
Vue2跟Vue3的对比
96 0
|
JavaScript 编译器 API
vue2 & vue3
### Vue 2和Vue 3之间的区别
|
JavaScript API
Vue(Vue2+Vue3)——77.Vue3.0
Vue(Vue2+Vue3)——77.Vue3.0
|
JavaScript 前端开发 API
vue2.0+vue3.0资料(八)
vue2.0+vue3.0资料(八)
133 1
|
缓存 JavaScript 前端开发
vue2.0+vue3.0资料(六)
vue2.0+vue3.0资料(六)
129 0
|
存储 缓存 JavaScript
vue2.0+vue3.0资料(七)
vue2.0+vue3.0资料(七)
124 0