溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3?pinia踩坑及解決實例代碼分析

發布時間:2023-03-06 14:54:51 來源:億速云 閱讀:233 作者:iii 欄目:開發技術

本篇內容主要講解“vue3 pinia踩坑及解決實例代碼分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“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()

使用中出現的問題

Cannot access 'useUserStore' before initialization

重現步驟

通常我們會在路由鉤子中判斷用戶是否登陸,從而進行權限判斷。如:

// 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')

問題原因

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

解決方案

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

// 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踩坑及解決實例代碼分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女