Vue中的全局路由守衛(wèi)beforeEach和狀態(tài)管理工具Vuex的store非常重要。beforeEach用于在路由跳轉(zhuǎn)前進(jìn)行中間件操作,store用于保存全局狀態(tài)。下面我們將討論如何結(jié)合使用這兩個(gè)重要的功能。
首先,我們需要引入Vue和Vuex。
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
然后,我們創(chuàng)建一個(gè)Vuex store實(shí)例。
const store = new Vuex.Store({
state: {
user: null
},
mutations: {
setUser(state, user){
state.user = user
}
}
})
在上面的代碼中,我們創(chuàng)建了一個(gè)名為user的state來(lái)保存用戶信息,并添加了一個(gè)名為setUser的mutation來(lái)更新用戶信息。
現(xiàn)在,我們可以在組件中使用store來(lái)更新和獲取全局狀態(tài)。例如:
export default {
computed: {
user() {
return this.$store.state.user
}
},
methods: {
login() {
// 登錄邏輯
const user = { name: '張三', age: 20 }
// 更新用戶信息
this.$store.commit('setUser', user)
}
}
}
接下來(lái),我們來(lái)結(jié)合beforeEach使用Vuex。假設(shè)我們有一個(gè)需要登錄才能訪問的頁(yè)面,我們可以在全局路由守衛(wèi)beforeEach中判斷用戶是否已經(jīng)登錄:
router.beforeEach((to, from, next) =>{
const user = store.state.user
const requiresAuth = to.matched.some(record =>record.meta.requiresAuth)
if (requiresAuth && !user) {
next('/login')
} else {
next()
}
})
在上面的代碼中,我們獲取當(dāng)前用戶信息并判斷需要認(rèn)證的頁(yè)面是否已經(jīng)登錄。如果沒有登錄,則跳轉(zhuǎn)到登錄頁(yè);否則,繼續(xù)向下執(zhí)行。
最后在路由中添加meta來(lái)標(biāo)記需要認(rèn)證的頁(yè)面:
const routes = [
{ path: '/', component: Home },
{ path: '/about', component: About },
{ path: '/login', component: Login },
{ path: '/dashboard', component: Dashboard, meta: { requiresAuth: true } }
]
現(xiàn)在,我們完成了使用Vuex和beforeEach來(lái)實(shí)現(xiàn)頁(yè)面認(rèn)證的功能。這種結(jié)合方式可以使頁(yè)面認(rèn)證更加方便、簡(jiǎn)潔、高效。