vue3 pinia踩坑及解決方案詳解
安裝
yarn add pinia # or npm install pinia
用法
// user.ts import { defineStore } from 'pinia' export const useUserStore = defineStore({ id: 'user', state: () => ({ ... }), actions: { ... } }) // components.vue import { useUserStore } from '@/store/user' const userStore = useUserStore()
使用中出現(xiàn)的問(wèn)題
1、Cannot access 'useUserStore' before initialization
重現(xiàn)步驟
通常我們會(huì)在路由鉤子中判斷用戶是否登陸,從而進(jìn)行權(quán)限判斷。如:
// permission.ts import { NavigationGuardNext, RouteLocationNormalized } from 'vue-router' import router from './router' import { useUserStore } from './store/user' const userStore: any = useUserStore() router.beforeEach(async(to: RouteLocationNormalized, from: RouteLocationNormalized, next: NavigationGuardNext) => { // TODO 判斷是否登錄 if (userStore.name) { ... } }) // main.ts const app = createApp(App) app.use(createPinia()) import router from './router' import '@/permission' app.use(router) app.mount('#app')
問(wèn)題原因
代碼從上往下執(zhí)行過(guò)程中,遇到const userStore: any = useUserStore()
,會(huì)進(jìn)行用戶狀態(tài)模塊的獲取,但是應(yīng)用還沒(méi)有掛載,所以Pinia的全局狀態(tài)還沒(méi)有進(jìn)行初始化。造成了初始化用戶模塊狀態(tài)獲取時(shí),全局狀態(tài)并沒(méi)有初始化,所以造成了當(dāng)前問(wèn)題。
解決方案
在路由鉤子函數(shù)進(jìn)行用戶狀態(tài)模塊的獲取,調(diào)用路由鉤子的時(shí)候,意味著全局狀態(tài)已完全初始化完成。但會(huì)造成每次調(diào)用路由鉤子都獲取用戶狀態(tài)模塊,會(huì)造成資源的浪費(fèi)(當(dāng)然可以達(dá)到預(yù)期目的,但并不是我們需要的)。我們可以在外層聲明一個(gè)變量用來(lái)存儲(chǔ)狀態(tài),在路由鉤子中進(jìn)行判斷,如果當(dāng)前變量為空,也就意味著狀態(tài)還沒(méi)有進(jìn)行過(guò)獲取,在當(dāng)前情況下進(jìn)行狀態(tài)獲?。愃朴趩卫W罱K代碼:
// permission.ts import { NavigationGuardNext, RouteLocationNormalized } from 'vue-router' import router from './router' import { useUserStore } from './store/user' let userStore: any = null router.beforeEach(async(to: RouteLocationNormalized, from: RouteLocationNormalized, next: NavigationGuardNext) => { if (userStore === null) { userStore = useUserStore() } // TODO 判斷是否登錄 if (userStore.name) { ... } })
以上就是vue3 pinia踩坑及解決方案詳解的詳細(xì)內(nèi)容,更多關(guān)于vue3 pinia踩坑解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue $emit $refs子父組件間方法的調(diào)用實(shí)例
今天小編就為大家分享一篇Vue $emit $refs子父組件間方法的調(diào)用實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09Vue實(shí)現(xiàn)點(diǎn)擊導(dǎo)航欄當(dāng)前標(biāo)簽后變色功能
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)點(diǎn)擊導(dǎo)航欄當(dāng)前標(biāo)簽后變色功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08Vue報(bào)錯(cuò):TypeError:Cannot create property '
這篇文章主要介紹了Vue報(bào)錯(cuò):TypeError:Cannot create property 'xxx' on string 'xxxx'問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Vue 實(shí)現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù)
今天小編就為大家分享一篇Vue 實(shí)現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10vue實(shí)現(xiàn)簡(jiǎn)單全選和反選功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單全選和反選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09Springboot+Vue-Cropper實(shí)現(xiàn)頭像剪切上傳效果
這篇文章主要為大家詳細(xì)介紹了Springboot+Vue-Cropper實(shí)現(xiàn)頭像剪切上傳效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy
這篇文章主要介紹了vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04