news 2026/3/31 2:28:41

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/3/25 12:25:08

基于单片机的直流电机PWM调速系统

基于单片机的直流电机PWM调速系统设计与实现 第一章 引言 直流电机凭借结构简单、启动转矩大、调速性能好等优势&#xff0c;广泛应用于工业自动化、智能设备、机器人等领域。传统直流电机调速方式&#xff08;如串电阻调速&#xff09;存在能耗高、调速精度低、响应迟缓等问题…

作者头像 李华
网站建设 2026/3/28 8:45:30

【珍藏版】大语言模型训练全流程详解:从基础模型到AI助手的蜕变

文章详细介绍了大语言模型(LLM)的三大训练阶段&#xff1a;预训练(无监督学习掌握语言规则和世界认知)、监督微调(SFT提升输出有用性和合规性)、以及RLHF(利用人类反馈优化回答质量)。随着DeepSeek等公司开源训练方法&#xff0c;我们可通过调整训练流程来革新大语言模型表现。…

作者头像 李华
网站建设 2026/3/24 0:14:09

收藏!2025大模型风口已至,程序员转型必看指南

2025年的技术序幕刚拉开&#xff0c;AI领域就抛出了颠覆性“王炸”——DeepSeek的突破性进展如同惊雷贯耳&#xff0c;瞬间重构了IT从业者的职业赛道。阿里云抢先完成核心业务与Agent体系的深度绑定&#xff0c;字节跳动更直接将大模型开发能力纳入30%后端岗位的硬性指标&#…

作者头像 李华
网站建设 2026/3/29 6:56:21

5、Linux 串口硬件配置全解析

Linux 串口硬件配置全解析 1. 串口通信软件概述 在 Linux 系统中,有多种用于调制解调器连接的通信软件。其中,许多是终端程序,能让用户像坐在简单终端前一样拨号连接到其他计算机。传统的类 Unix 环境终端程序 kermit 如今已显陈旧,使用起来较为困难。现在有更便捷的程序…

作者头像 李华
网站建设 2026/3/24 1:53:26

16、Linux 中 IPX 与 NCP 文件系统的全面指南

Linux 中 IPX 与 NCP 文件系统的全面指南 1. 协议起源与发展 在 20 世纪 70 年代末,施乐公司开发并发布了施乐网络规范(XNS),这是一个用于通用互联网的开放标准,尤其侧重于局域网的使用。XNS 包含两个主要的网络协议: - 互联网数据报协议(IDP):提供无连接且不可靠的…

作者头像 李华
网站建设 2026/3/27 23:08:19

19、Sendmail:强大邮件程序的配置与管理指南

Sendmail:强大邮件程序的配置与管理指南 1. Sendmail 简介 Sendmail 是一款功能强大但学习和理解难度较大的邮件程序。过去,配置 Sendmail 需要直接编辑复杂的 sendmail.cf 文件,这让很多人望而却步。不过,新版本的 Sendmail 提供了配置工具,可根据简单的宏文件生成 sen…

作者头像 李华