亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue3 pinia踩坑及解決方案詳解

 更新時間:2023年03月06日 10:10:11   作者:黑狼傳說  
這篇文章主要為大家介紹了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)的問題

1、Cannot access 'useUserStore' before initialization

重現(xià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')

問題原因

代碼從上往下執(zhí)行過程中,遇到const userStore: any = useUserStore(),會進行用戶狀態(tài)模塊的獲取,但是應用還沒有掛載,所以Pinia的全局狀態(tài)還沒有進行初始化。造成了初始化用戶模塊狀態(tài)獲取時,全局狀態(tài)并沒有初始化,所以造成了當前問題。

解決方案

在路由鉤子函數(shù)進行用戶狀態(tài)模塊的獲取,調用路由鉤子的時候,意味著全局狀態(tài)已完全初始化完成。但會造成每次調用路由鉤子都獲取用戶狀態(tài)模塊,會造成資源的浪費(當然可以達到預期目的,但并不是我們需要的)。我們可以在外層聲明一個變量用來存儲狀態(tài),在路由鉤子中進行判斷,如果當前變量為空,也就意味著狀態(tài)還沒有進行過獲取,在當前情況下進行狀態(tài)獲?。愃朴趩卫?。最終代碼:

// 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踩坑及解決方案詳解的詳細內(nèi)容,更多關于vue3 pinia踩坑解決的資料請關注腳本之家其它相關文章!

相關文章

  • vue實現(xiàn)登錄攔截

    vue實現(xiàn)登錄攔截

    這篇文章主要介紹了vue實現(xiàn)登錄攔截,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • Vue $emit $refs子父組件間方法的調用實例

    Vue $emit $refs子父組件間方法的調用實例

    今天小編就為大家分享一篇Vue $emit $refs子父組件間方法的調用實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解vue-cli 腳手架 安裝

    詳解vue-cli 腳手架 安裝

    這篇文章主要介紹了vue-cli腳手架安裝,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Vue實現(xiàn)點擊導航欄當前標簽后變色功能

    Vue實現(xiàn)點擊導航欄當前標簽后變色功能

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)點擊導航欄當前標簽后變色功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Vue報錯:TypeError:Cannot create property 'xxx' on string 'xxxx'問題

    Vue報錯:TypeError:Cannot create property '

    這篇文章主要介紹了Vue報錯:TypeError:Cannot create property 'xxx' on string 'xxxx'問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue 實現(xiàn)把表單form數(shù)據(jù) 轉化成json格式的數(shù)據(jù)

    Vue 實現(xiàn)把表單form數(shù)據(jù) 轉化成json格式的數(shù)據(jù)

    今天小編就為大家分享一篇Vue 實現(xiàn)把表單form數(shù)據(jù) 轉化成json格式的數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue?全部生命周期組件梳理整理

    Vue?全部生命周期組件梳理整理

    這篇文章主要介紹了Vue?全部生命周期組件梳理整理,在創(chuàng)建組件之前使用;在實例初始化之后,進行數(shù)據(jù)偵聽和事件,偵聽器的配置之前同步調用
    2022-06-06
  • vue實現(xiàn)簡單全選和反選功能

    vue實現(xiàn)簡單全選和反選功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)簡單全選和反選功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Springboot+Vue-Cropper實現(xiàn)頭像剪切上傳效果

    Springboot+Vue-Cropper實現(xiàn)頭像剪切上傳效果

    這篇文章主要為大家詳細介紹了Springboot+Vue-Cropper實現(xiàn)頭像剪切上傳效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    這篇文章主要介紹了vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論