深入了解 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:点击主界面左…...
UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
Linux链表操作全解析
Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表?1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...
微信小程序之bind和catch
这两个呢,都是绑定事件用的,具体使用有些小区别。 官方文档: 事件冒泡处理不同 bind:绑定的事件会向上冒泡,即触发当前组件的事件后,还会继续触发父组件的相同事件。例如,有一个子视图绑定了b…...
AI Agent与Agentic AI:原理、应用、挑战与未来展望
文章目录 一、引言二、AI Agent与Agentic AI的兴起2.1 技术契机与生态成熟2.2 Agent的定义与特征2.3 Agent的发展历程 三、AI Agent的核心技术栈解密3.1 感知模块代码示例:使用Python和OpenCV进行图像识别 3.2 认知与决策模块代码示例:使用OpenAI GPT-3进…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...
使用分级同态加密防御梯度泄漏
抽象 联邦学习 (FL) 支持跨分布式客户端进行协作模型训练,而无需共享原始数据,这使其成为在互联和自动驾驶汽车 (CAV) 等领域保护隐私的机器学习的一种很有前途的方法。然而,最近的研究表明&…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
ArcGIS Pro制作水平横向图例+多级标注
今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作:ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等(ArcGIS出图图例8大技巧),那这次我们看看ArcGIS Pro如何更加快捷的操作。…...
DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”
目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...
