Vue3使用Pinia获取全局状态变量

Pinia 是 Vue 3 的状态管理库,用于替代 Vuex。使用 Pinia,你可以轻松地在 Vue 3 应用中管理全局状态。下面是如何使用 Pinia 获取全局状态变量的说明和代码示例:

安装 Pinia

首先,确保你已经安装了 Vue 3 和 Pinia:

复制代码
`npm install vue@next pinia@next`

创建 Pinia Store

创建一个 Pinia store 来存储你的全局状态:

复制代码
javascript`// stores/index.js
import { createPinia } from 'pinia';
import app from '../src/app'; // Vue 3 app instance

const pinia = createPinia();
app.use(pinia);`

创建 Store

stores 目录下创建一个新的 store:

复制代码
`// stores/myGlobalStore.js
import { defineStore } from 'pinia';

export const useMyGlobalStore = defineStore('myGlobalStore', {
state: () => ({
count: 0,
}),
actions: {
increment() {
this.count++;
},
},
});`

在组件中使用 Store

现在你可以在任何 Vue 组件中使用这个 store:

复制代码
`// src/components/MyComponent.vue
<template>
<div>
<p>Count: {``{ count }}</p>
<button @click="incrementCount">Increment</button>
</div>
</template>

<script>
import { useMyGlobalStore } from '../stores/myGlobalStore'; // import your store here

export default {
setup() {
const myGlobalStore = useMyGlobalStore(); // use your store here
const incrementCount = () => { myGlobalStore.increment(); }; // use the action in your store here
return { count: myGlobalStore.count, incrementCount }; // expose your state and actions to the template here
},
};
</script>`

初始化全局状态

src/main.js 或类似的入口文件中,确保你在创建 Vue 实例之前初始化 Pinia store:

复制代码
`import { createApp } from 'vue';
import App from './App.vue'; // your main Vue component here
import { createPinia } from 'pinia'; // import Pinia here if you haven't already done so in your store setup file (step 2)
import { useMyGlobalStore } from './stores/myGlobalStore'; // import your store here if you haven't already done so in your component (step 4) or store setup file (step 3)
// ... other imports ...`
相关推荐
qq_1777673716 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头882119 分钟前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
程序员清洒2 小时前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
雨季6662 小时前
Flutter 三端应用实战:OpenHarmony 简易“动态内边距调节器”交互模式深度解析
javascript·flutter·ui·交互·dart
天人合一peng3 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
会飞的战斗鸡3 小时前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
方也_arkling4 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
qq_177767374 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767374 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体