news 2026/4/13 3:04:47

Vue3使用pinia做全局状态管理的简单示例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue3使用pinia做全局状态管理的简单示例

一、插件版本:

"pinia": "^2.0.23",

"pinia-plugin-persist": "^1.0.0",

"vue": "^3.4.27"

二、store目录

src/store/index.ts

import type { App } from 'vue'; import { createPinia } from 'pinia'; import piniaPersist from 'pinia-plugin-persist'; const store = createPinia(); store.use(piniaPersist); export function setupStore(app: App<Element>) { app.use(store); } export { store };

src/store/tableStore.ts

import { Ref, ref } from 'vue'; import { defineStore } from 'pinia'; import { store } from '@/store'; export interface ITableStoreState { tableRef: Ref; list: Map<any, any>[]; } export const tableOrgStore = defineStore({ id: 'tableOrganization', state: (): ITableStoreState => ({ tableRef: ref(), list: [], }), persist: { enabled: true, }, getters: { getList(): ITableStoreState['list'] { return this.list; }, }, actions: { setList(info: ITableStoreState['list']) { this.list = info; }, }, }); // Need to be used outside the setup export function useTableStoreWidthOut() { return tableOrgStore(store); }

三、main.ts

。。。省略。。。 // 挂载状态管理 setupStore(app); 。。。省略。。。

四、在main.ts所在项目的任意组件中使用:

import { storeToRefs } from 'pinia'; import { useTableStoreWidthOut } from '@/store/modules/tableStore'; const tableStore = useTableStoreWidthOut(); const { tableRef, getList } = storeToRefs(tableStore); // 响应式数据使用storeToRefs包裹再解构获取 const { setList } = tableStore; // function方法直接解构获取

使用tableRef示例:

<template> <button @click="handleClick">click</button> <my-list ref="tableRef" /> </template> <script lang="ts" setup> import { storeToRefs } from 'pinia'; import { useTableStoreWidthOut } from '@/store/modules/tableStore'; import MyList from './MyList.vue'; const tableStore = useTableStoreWidthOut(); const { tableRef } = storeToRefs(tableStore); // 响应式数据使用storeToRefs包裹再解构获取 const handleClick = () => { console.log('===tableRef====', tableRef); }; </script>

五、参考资料

https://pinia.vuejs.org/core-concepts/

https://prazdevs.github.io/pinia-plugin-persistedstate/zh/guide/

https://cn.vuejs.org/api/application.html

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 21:03:41

基于C技术与SOCKET网络通信技术的局域网聊天系统

**# 基于C技术与SOCKET网络通信技术的局域网聊天系统 第一章 系统概述 在企业办公、校园协作等局域网场景中&#xff0c;传统即时通信工具依赖公网服务器&#xff0c;存在数据隐私泄露风险与网络延迟问题&#xff0c;而基于C技术与Socket网络通信的局域网聊天系统&#xff0c;通…

作者头像 李华
网站建设 2026/4/12 3:03:13

LobeChat实时流式输出实现原理剖析

LobeChat 实时流式输出实现原理剖析 在构建现代 AI 聊天应用的今天&#xff0c;用户早已不再满足于“发送问题、等待答案”的传统交互模式。当大语言模型&#xff08;LLM&#xff09;开始进入千家万户&#xff0c;用户体验的边界也被不断拉高——人们期望看到文字像人类打字一…

作者头像 李华
网站建设 2026/4/9 12:16:45

人人都在谈大模型,但90%的企业AI转型,都死在了数据这一关

从CEO到一线员工&#xff0c;几乎所有人都在热烈地讨论着大模型的最新进展和各种眼花缭乱的AI应用。我们仿佛进入了一个模型为王的时代&#xff0c;似乎只要接入最强的模型&#xff0c;就能解决所有问题。但现实是残酷的。 为什么很多企业AI项目总是做不出来&#xff1f; 我们也…

作者头像 李华
网站建设 2026/4/6 23:40:16

机器学习--线性回归

1、线性回归定义线性回归是利用数理统计中回归分析&#xff0c;来确定两种或两种以上变量间相互依赖的定量关系的一种统计分析方法。相关关系:包含因果关系和平行关系因果关系:回归分析【原因引起结果&#xff0c;需要明确自变量和因变量平行关系:相关分析【无因果关系&#xf…

作者头像 李华
网站建设 2026/4/8 23:20:04

LobeChat系统稳定性承诺书

LobeChat系统稳定性与架构深度解析 在生成式AI迅猛发展的今天&#xff0c;大语言模型&#xff08;LLMs&#xff09;早已不再是研究实验室里的“黑箱”&#xff0c;而是逐步走进千家万户的生产力工具。然而&#xff0c;一个常被忽视的问题是&#xff1a;再强大的模型&#xff0…

作者头像 李华
网站建设 2026/3/29 19:18:44

代码之恋(第十二篇:公开的合并与意外的提交)

周一的 办公室&#xff0c;晨光刚漫过工位隔板&#xff0c;咖啡机还在 “咕嘟咕嘟” 预热&#xff0c;空气里飘着速溶咖啡和隔夜外卖的混合气味 —— 典型的 “节后重启失败” 现场。李磊站在电梯口等艾丽&#xff0c;指尖无意识地摩挲着手机壳边缘&#xff0c;心里像跑着十个异…

作者头像 李华