深入了解 Pinia:现代 Vue 应用的状态管理利器

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》
文章目录
- 一、引言
- 简要介绍 Pinia
- 二、Pinia 是什么?
- Pinia 的定义和功能
- Pinia 与其他状态管理库的比较
- 三、安装和配置 Pinia
- 在项目中安装 Pinia
- 配置 Pinia
- 四、总结
- 总结 Pinia 的优点和适用场景
一、引言
简要介绍 Pinia
Pinia 是一个用于 Vue.js 的轻量级状态管理库。它提供了一种简单直观的方式来管理应用程序的状态,使开发者能够更好地组织和维护应用程序的数据。
使用 Pinia,你可以将应用程序的状态存储在一个集中的位置,并通过 Vue 组件进行访问和修改。 Pinia 支持模块化的状态管理,允许你将状态划分为不同的模块,从而提高代码的可维护性和可扩展性。
Pinia 还提供了一些高级功能,如状态订阅、缓存和持久化等,使你能够更好地处理复杂的状态管理需求。它与 Vue.js 的生态系统无缝集成,并且具有出色的性能和易用性。

总的来说,Pinia 是一个强大而灵活的状态管理解决方案,适用于各种规模的 Vue.js 应用程序。它简化了状态管理的工作流程,并提供了一种简洁明了的方式来处理应用程序的数据。
二、Pinia 是什么?
Pinia 的定义和功能
Pinia 是一个用于 Vue.js 的状态管理库。它提供了一种简单直观的方式来管理应用程序的状态,使开发者能够更好地组织和维护应用程序的数据。
Pinia 的主要功能包括:

- 状态管理:提供了一个集中的位置来存储和管理应用程序的状态。
- 模块化状态:
支持将状态划分为不同的模块,提高代码的可维护性和可扩展性。 - 状态订阅:允许你订阅状态的变化,并在状态发生变化时触发相应的回调函数。
- 缓存和持久化:
支持缓存状态数据,以提高性能。同时,也支持将状态数据持久化到本地存储或后端数据库中。 - 与 Vue.js 生态系统无缝集成:与 Vue.js 的其他工具和库配合良好,可以轻松地与 Vuex、Vue Router 等一起使用。
总的来说,Pinia 提供了一种简洁明了的方式来处理应用程序的数据,简化了状态管理的工作流程,并提高了应用程序的可维护性和可扩展性。它适用于各种规模的 Vue.js 应用程序,是一个强大而灵活的状态管理解决方案。
Pinia 与其他状态管理库的比较
| 比较项目 | Pinia | Vuex |
|---|---|---|
| 大小 | 轻量级(约 4KB) | 较大(约 22KB) |
| 学习曲线 | 相对较低 | 相对较高 |
| 模块化 | 支持 | 支持 |
| 类型支持 | 支持 | 不支持 |
| 可组合性 | 高 | 高 |
| 性能 | 优秀 | 优秀 |
请注意,这只是一个简单的比较,实际使用情况可能因具体需求和项目情况而有所不同。
三、安装和配置 Pinia
在项目中安装 Pinia
在项目中安装 Pinia 可以通过以下步骤进行:
- 首先,确保你已经安装了 Vue.js。如果还没有安装,可以使用以下命令进行安装:
npm install vue
- 接下来,安装 Pinia。可以使用以下命令进行安装:
npm install pinia
- 在 Vue 项目的
main.js文件中,引入 Pinia,并将其注册为 Vue 的插件:
import { createPinia } from 'pinia';const app = createApp(App);app.use(createPinia());app.mount('#app');
这样,你就成功地在项目中安装了 Pinia。接下来,你可以在 Vue 组件中使用 Pinia 来管理状态。
配置 Pinia
在使用 Pinia 管理状态之前,你需要对其进行一些基本的配置。以下是一些常见的配置选项:
- 创建 store:在 Pinia 中,状态被存储在一个名为 store 的对象中。你可以根据应用程序的需求创建多个 store,每个 store 对应一个模块或功能。
例如,你可以创建一个名为 user 的 store,用于管理用户的状态:
import { createPinia } from 'pinia';const app = createApp(App);const pinia = createPinia();app.use(pinia);const userStore = pinia.createStore({state: {name: 'John Doe',age: 30}
});app.mount('#app');
在上述示例中,我们创建了一个名为 user 的 store,并定义了一个初始状态。你可以根据需要在 store 中定义更多的状态变量。
- 访问和修改状态:在 Vue 组件中,可以通过
useStore方法访问和修改 store 中的状态。
例如,在上述示例中,我们可以在一个 Vue 组件中访问和修改 user store 的状态:
import { useStore } from 'pinia';export default {name: 'UserDetails',setup() {const userStore = useStore(userStore);return {name: userStore.name,age: userStore.age};}
};
在上述示例中,我们使用 useStore 方法获取 user store 的实例,并将其赋值给 userStore 变量。然后,我们可以在组件的模板中访问和修改 userStore 的状态。
- 状态订阅:除了直接访问和修改状态,你还可以订阅 store 中的状态变化,并在状态发生变化时触发相应的回调函数。
例如,在上述示例中,我们可以在 user store 中添加一个状态订阅:
import { createPinia } from 'pinia';const app = createApp(App);const pinia = createPinia();app.use(pinia);const userStore = pinia.createStore({state: {name: 'John Doe',age: 30},actions: {setName(newName) {this.name = newName;}},getters: {getName() {return this.name;}},subscriptions: {updateName() {console.log('Name changed to:', this.getName());}}
});app.mount('#app');
在上述示例中,我们在 subscriptions 选项中定义了一个名为 updateName 的订阅函数。当 user store 中的 name 状态发生变化时,updateName 函数将被触发,并在控制台中输出新的名字。
这只是 Pinia 的一些基本配置选项,你可以根据实际需求进行更多的定制和扩展。根据具体的项目需求,你可能需要进一步配置缓存、持久化、模块和命名空间等内容。请查阅 Pinia 的官方文档以获取更详细的信息和示例。
四、总结
总结 Pinia 的优点和适用场景
Pinia 是一个轻量级的状态管理库,它具有以下优点和适用场景:
优点:
- 轻量级:Pinia 是一个轻量级的库,它的大小只有约 4KB,因此在项目中引入 Pinia 不会增加太多的额外负担。
- 简单易用:
Pinia 的 API 设计简单直观,学习曲线相对较低,使得开发者能够快速上手并高效地管理应用程序的状态。 - 模块化: Pinia 支持模块化的状态管理,你可以将状态划分为不同的模块,并在不同的模块中定义各自的状态变量和操作。这有助于提高代码的可维护性和可扩展性。
- 类型支持: Pinia 提供了类型支持,使得你可以在 TypeScript 项目中获得更好的类型检查和开发体验。
- 可组合性:
Pinia 支持组合多个 store,你可以将不同的状态管理逻辑拆分成独立的 store,并通过组合它们来构建复杂的应用程序状态管理架构。

适用场景:
- 单页应用程序(SPA): Pinia 非常适合用于管理 SPA 中的状态,因为它提供了一种简单直观的方式来管理和共享状态数据。
- 状态管理复杂的应用程序:
如果你的应用程序需要管理大量的状态数据,并且状态之间存在复杂的依赖关系,那么 Pinia 可以帮助你简化状态管理的工作流程,提高代码的可维护性。 - 与 Vue.js 生态系统的集成: Pinia 是专门为 Vue.js 设计的状态管理库,它与 Vue.js 的生态系统无缝集成,可以与 Vuex、Vue Router 等其他库配合使用。
- 可扩展性和可测试性要求较高的项目: Pinia 的模块化和可组合性使得它能够适应复杂的项目需求,并提供良好的可扩展性和可测试性。

总的来说,Pinia 是一个简单易用、功能强大的状态管理库,适用于各种规模的 Vue.js 应用程序。它提供了一种简洁明了的方式来管理状态,提高了代码的可维护性和可扩展性。如果你需要在 Vue.js 项目中管理状态,并且希望保持代码的简洁和高效,那么 Pinia 是一个值得考虑的选择。
相关文章:
深入了解 Pinia:现代 Vue 应用的状态管理利器
🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云…...
TTS声音合成:paddlespeech、sherpa-onnx、coqui-ai
1、百度TTS文本合成语音 参考: https://aistudio.baidu.com/aistudio/projectdetail/5237474 https://www.jianshu.com/p/a7522ca6dec4 https://github.com/PaddlePaddle/PaddleSpeech/blob/develop/demos/text_to_speech/README_cn.md 1)过程中需要下载的TTS 声学相关模型…...
Android frameworks 开发总结之十一
1.查看android关机前的log 有时候我们在没有连接电脑的情况下,会在测试的时候突然机器关机. 这个时候如果查看 log信息就看不到了。测试前可以执行下面的命令,之后再进行测试. $ adb shell $ nohup logcat > /sdcard/xxx.log 2.android日期时间同步 关于…...
抑制过拟合——Dropout原理
抑制过拟合——Dropout原理 Dropout的工作原理 实验观察 在机器学习领域,尤其是当我们处理复杂的模型和有限的训练样本时,一个常见的问题是过拟合。简而言之,过拟合发生在模型对训练数据学得太好,以至于它捕捉到了数据中的噪声和…...
开发板启动进入系统以后再挂载 NFS 文件系统, 这里的NFS文件系统是根据正点原子教程制作的ubuntu_rootfs
如果是想开发板启动进入系统以后再挂载 NFS 文件系统,开发板启动进入文件系统,开发板和 ubuntu 能互相 ping 通,在开发板文件系统下新建一个目录 you,然后执行如下指令进行挂载: mkdir mi mount -t nfs -o nolock,nfsv…...
Ubuntu系统执行“docker ps“出现“permission denied“
当我们安装好Ubuntu时,使用鱼香ros一键安装指令 wget http://fishros.com/install -O fishros && . fishros 一键安装Docker后,执行"docker ps"出现"permission denied" seelina:~$ docker ps permission denied while …...
Python与设计模式--桥梁模式
23种计模式之 前言 (5)单例模式、工厂模式、简单工厂模式、抽象工厂模式、建造者模式、原型模式、(7)代理模式、装饰器模式、适配器模式、门面模式、组合模式、享元模式、桥梁模式、(11)策略模式、责任链模式、命令模式、中介者模…...
Linux下查看目录大小
查看目录大小 Linux下查看当前目录大小,可用一下命令: du -h --max-depth1它会从下到大的显示文件的大小。...
鸿蒙原生应用/元服务开发-AGC分发如何下载管理Profile
一、收到通知 尊敬的开发者: 您好,为支撑鸿蒙生态发展,HUAWEI AppGallery Connect已于X月XX日完成存量HarmonyOS应用/元服务的Profile文件更新,更新后Profile文件中已扩展App ID信息;后续上架流程会检测API9以上Harm…...
解决warning: #188-D: enumerated type mixed with another type问题
出现问题处如下, 指示在代码的某处将枚举类型与另一种类型混合使用,这种警告通常在将枚举类型与其他类型进行操作或赋值时出现 enum Mode {MODE_IDLE,MODE_1,MODE_2,MODE_3,MODE_4, }; enum Mode currentMode MODE_IDLE;currentMode (currentMode 1)…...
docker的知识点,以及使用
Docker 是一个开源的应用容器引擎,可以让开发者将应用程序及其依赖项打包至一个可移植的容器中,从而实现快速部署、可扩展和依赖项隔离等特性。下面是 Docker 的一些知识点以及使用方法: Docker 的组成部分包括 Docker 引擎、Docker 镜像、Do…...
WTM(基于Blazor)问题处理记录
问题描述一 有个需求,需要访问内网网络共享文件夹中的文件,有域控限制。 一开始直接在本地映射一个网络驱动器,然后像本地磁盘一样访问共享文件夹里的文件,比如:Y:\ 。 然后直接在程序中访问共享文件夹中的文件,如下代码: DirectoryInfo directoryInfo = new Direct…...
ubuntu 安装 towhee
安装Towhee pip3 install towhee如果你想在 towhee 中安装模型 pip3 install towhee.models打开python终端 python3引入towhee 数据转换是 Towhee 的核心;管道只是在有向无环图中连接在一起的一系列转换。所有预构建的 Towhee 管道都有代表当前任务的名称。 fr…...
ERP软件对Oracle安全产品的支持
这里的ERP软件仅指SAP ECC和Oracle EBS。 先来看Oracle EBS: EBS的认证查询方式,和数据库认证是一样的。这个体验到时不错。 结果中和安全相关的有: Oracle Database VaultTransparent Data Encryption TDE被支持很容易理解,…...
Linux 基础-常用的命令和搭建 Java 部署环境
文章目录 目录相关查看目录中的内容查看目录当前的完整路径切换目录 文件相关创建文件查看文件内容写文件vim 基础 创建删除创建目录 移动和复制移动(剪切粘贴)复制(复制粘贴) 搭建 Java 部署环境1. 安装 jdk2. 安装 tomcat1). 我们在自己电脑上下好 tomcat2). 从官网下载的 .z…...
c语言总结(解题方法)
项目前期处理: 1.首先需要确定项目的背景知识,即主要的难点知识,如指针,数组,结构体,以检索自己是否对项目所需的背景知识足够了解。 2.确定问题实现方法,即题目本身的实现方法,在c语…...
Webpack的ts的配置详细教程
文章目录 前言ts是什么?基础配置LoaderSource MapsClient types使用第三方类库导入其他资源 后言 前言 hello world欢迎来到前端的新世界 😜当前文章系列专栏:webpack 🐱👓博主在前端领域还有很多知识和技术需要掌握…...
传智杯第五届题解
B.莲子的机械动力学 分析:这题有个小坑,如果是00 0,结果记得要输出0。 得到的教训是,避免前导0出现时,要注意答案为0的情况。否则有可能会没有输出 #include<assert.h> #include<cstdio> #include<…...
Android 通过demo调试节点权限问题
Android 通过demo调试节点权限问题 近来收到客户反馈提到在应用层无法控制节点,于是写了一个简单的demo来验证节点的IO权限,具体调试步骤就是写一个按钮点击事件,当点击按钮时将需要验证的节点写为1(节点默认为1则写为0ÿ…...
邮政快递物流查询,将指定某天签收的单号筛选出来
批量查询邮政快递单号的物流信息,将指定某天签收的单号筛选出来。 所需工具: 一个【快递批量查询高手】软件 邮政快递单号若干 操作步骤: 步骤1:运行【快递批量查询高手】软件,并登录 步骤2:点击主界面左…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...
MySQL 8.0 事务全面讲解
以下是一个结合两次回答的 MySQL 8.0 事务全面讲解,涵盖了事务的核心概念、操作示例、失败回滚、隔离级别、事务性 DDL 和 XA 事务等内容,并修正了查看隔离级别的命令。 MySQL 8.0 事务全面讲解 一、事务的核心概念(ACID) 事务是…...
Scrapy-Redis分布式爬虫架构的可扩展性与容错性增强:基于微服务与容器化的解决方案
在大数据时代,海量数据的采集与处理成为企业和研究机构获取信息的关键环节。Scrapy-Redis作为一种经典的分布式爬虫架构,在处理大规模数据抓取任务时展现出强大的能力。然而,随着业务规模的不断扩大和数据抓取需求的日益复杂,传统…...
消息队列系统设计与实践全解析
文章目录 🚀 消息队列系统设计与实践全解析🔍 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡💡 权衡决策框架 1.3 运维复杂度评估🔧 运维成本降低策略 🏗️ 二、典型架构设计2.1 分布式事务最终一致…...
Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践
在 Kubernetes 集群中,如何在保障应用高可用的同时有效地管理资源,一直是运维人员和开发者关注的重点。随着微服务架构的普及,集群内各个服务的负载波动日趋明显,传统的手动扩缩容方式已无法满足实时性和弹性需求。 Cluster Auto…...
医疗AI模型可解释性编程研究:基于SHAP、LIME与Anchor
1 医疗树模型与可解释人工智能基础 医疗领域的人工智能应用正迅速从理论研究转向临床实践,在这一过程中,模型可解释性已成为确保AI系统被医疗专业人员接受和信任的关键因素。基于树模型的集成算法(如RandomForest、XGBoost、LightGBM)因其卓越的预测性能和相对良好的解释性…...
GraphRAG优化新思路-开源的ROGRAG框架
目前的如微软开源的GraphRAG的工作流程都较为复杂,难以孤立地评估各个组件的贡献,传统的检索方法在处理复杂推理任务时可能不够有效,特别是在需要理解实体间关系或多跳知识的情况下。先说结论,看完后感觉这个框架性能上不会比Grap…...
【题解-洛谷】P10480 可达性统计
题目:P10480 可达性统计 题目描述 给定一张 N N N 个点 M M M 条边的有向无环图,分别统计从每个点出发能够到达的点的数量。 输入格式 第一行两个整数 N , M N,M N,M,接下来 M M M 行每行两个整数 x , y x,y x,y,表示从 …...
[QMT量化交易小白入门]-六十二、ETF轮动中简单的评分算法如何获取历史年化收益32.7%
本专栏主要是介绍QMT的基础用法,常见函数,写策略的方法,也会分享一些量化交易的思路,大概会写100篇左右。 QMT的相关资料较少,在使用过程中不断的摸索,遇到了一些问题,记录下来和大家一起沟通,共同进步。 文章目录 相关阅读1. 策略概述2. 趋势评分模块3 代码解析4 木头…...
性能优化中,多面体模型基本原理
1)多面体编译技术是一种基于多面体模型的程序分析和优化技术,它将程序 中的语句实例、访问关系、依赖关系和调度等信息映射到多维空间中的几何对 象,通过对这些几何对象进行几何操作和线性代数计算来进行程序的分析和优 化。 其中࿰…...
