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 ...`
相关推荐
华玥作者6 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_7 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠7 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog7 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang201509287 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC8 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务8 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_247438618 小时前
Android ViewModel定时任务
android·开发语言·javascript
嘿起屁儿整9 小时前
面试点(网络层面)
前端·网络
VT.馒头9 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript