当前位置: 首页 > news >正文

前端工程化:pinia

本文为个人学习笔记整理,仅供交流参考,非专业教学资料,内容请自行甄别。

文章目录

  • 前言
  • 一、初始化Pinia
  • 二、业务处理


前言

  Pinia是Vue.js官方推荐的状态管理库,什么是状态管理库状态管理库是用于管理应用程序中共享状态的工具,核心作用是解决
多个组件之间的数据共享、状态同步和逻辑复用的问题。类似于JAVA中的ThreadLocal,或Redis。
  为什么需要状态管理?在复杂的 Vue 应用中,组件之间的关系可能很复杂(如父子、兄弟、跨层级组件),如果仅通过props传递数据或$emit触发事件,会导致:

  • 数据传递链路过长(如跨多层级组件),维护困难;
  • 多个组件依赖同一份数据时,难以同步更新(如一个组件修改数据后,其他依赖组件无法自动感知);
  • 业务逻辑分散在各个组件中,复用和调试成本高。

  状态管理库通过将共享数据集中存储,并提供统一的读写规则,让所有组件都能高效地访问和修改这些数据,确保状态变化的可预测性。
  状态管理库的核心能力,首先是集中存储,将共享状态从组件中抽离,统一存放在 “仓库(Store)” 中,所有组件都能从仓库中获取数据。并且支持响应式更新,当仓库中的状态发生变化时,所有依赖该状态的组件会自动重新渲染。
  常见的状态管理库,除了Pinia,还有Vuex等选择。

一、初始化Pinia

  首先需要通过如下的命令,在项目中引入Pinia:

npm install pinia

  并且需要在main.js中进行挂载:

import { createApp } from 'vue'
import { createPinia } from 'pinia'import App from './App.vue'
const app = createApp(App)app.use(createPinia())
app.mount('#app')

  上述配置完成后,创建具体的store存储文件,在store中有三个概念:

  • state:用于存储组件的状态数据。
  • getter:用于对state中的数据进行计算或加工处理后返回。
  • action:用于定义对于状态数据的业务逻辑的处理
import { defineStore } from 'pinia'
import { ref } from 'vue'export const useLoginUserStore = defineStore('loginUser', () => {const loginUser = ref<any>({userName: '未登录',})async function fetchLoginUser() {// todo 由于后端还没提供接口,暂时注释// const res = await getCurrentUser();// if (res.data.code === 0 && res.data.data) {//   loginUser.value = res.data.data;// }setTimeout(() => {loginUser.value = { userName: '测试用户',id:1848 }}, 3000)}function setLoginUser(newLoginUser: any) {loginUser.value = newLoginUser}return { loginUser, setLoginUser, fetchLoginUser }
})

二、业务处理

  如果需要在其他组件使用刚刚定义好的store,则需要先在script标签中引入:

const loginUserStore = useLoginUserStore()
loginUserStore.fetchLoginUser()

  然后具体的进行处理,可以取出其中的属性用于判断,也可以调用store中的方法。

<!--          从全局状态管理器中取出用户id-->
<div v-if="loginUserStore.loginUser.id">{{ loginUserStore.loginUser.userName ?? '褪色者' }}
</div>

在这里插入图片描述


http://www.dtcms.com/a/326872.html

相关文章:

  • 【Leetcode】随笔
  • 【MATLAB 2025a】安装离线帮助文档
  • 学习嵌入式之IMAX6ULL——GUN工具链+点灯+SDK开发裸机驱动
  • 计算机网络:ovn数据通信都是用了哪些协议?
  • Java String类:不可变性的核心奥秘
  • Evaluation Warning: The document was created with Spire.XLS for Pyth用Python实现Excel转PDF并去除Spire.XLS水印
  • 银河通用招人形机器人强化学习算法工程师了
  • Python 类元编程(类工厂函数)
  • C语言(06)——二、八、十、十六进制的相互转换
  • Webpack Loader 完全指南:从原理到配置的深度解析
  • TRL - Transformer Reinforcement Learning 传递给SFTTrainer的数据集
  • 【linux】企业高性能web服务器
  • 多路转接 select
  • FinQ4Cn: 基于 MCP 协议的中国 A 股量化分析
  • CSS预处理器之Sass全面解析与实战指南
  • PowerDesigner生成带注释的sql方法
  • 腾讯前端面试模拟详解
  • 分享一款基于STC32G12K128单片机的螺丝机供料器控制板 ES-IO2422 S4
  • 浅谈 LangGraph 子图流式执行(subgraphs=True/False)模式
  • [鹧鸪云]光伏AI设计平台解锁电站开发新范式
  • Kubernetes生产环境健康检查自动化指南
  • Centos8系统在安装Git包时,报错:“没有任何匹配: git”
  • 【ros-humble】4.C++写法巡场海龟(服务通讯)
  • 搭建纯竞拍商城的核心技术要点与实施指南
  • 4-下一代防火墙组网方案
  • [Element-plus]动态设置组件的语言
  • GPT-oss:OpenAI再次开源新模型,技术报告解读
  • 【无标题】matplotlib与seaborn数据库
  • 基于FPGA的热电偶测温数据采集系统,替代NI的产品(二)总体设计方案
  • 嵌入式硬件中AI硬件设计方法与技巧