關(guān)于Vue中的全局導(dǎo)航守衛(wèi)(beforeEach、afterEach)
全局導(dǎo)航守衛(wèi)(beforeEach、afterEach)
在項目開發(fā)中每一次路由的切換或者頁面的刷新都需要判斷用戶是否已經(jīng)登錄,前端可以判斷,后端也會進(jìn)行判斷的,我們前端最好也進(jìn)行判斷。
vue-router 提供了導(dǎo)航鉤子:全局前置導(dǎo)航鉤子 beforeEach 和全局后置導(dǎo)航鉤子 afterEach,他們會在路由即將改變前和改變后進(jìn)行觸發(fā)。所以判斷用戶是否登錄需要在 beforeEach 導(dǎo)航鉤子中進(jìn)行判斷。
導(dǎo)航鉤子有3個參數(shù)
1、to:即將要進(jìn)入的目標(biāo)路由對象;
2、from:當(dāng)前導(dǎo)航即將要離開的路由對象;
3、next :調(diào)用該方法后,才能進(jìn)入下一個鉤子函數(shù)(afterEach)。
next()//直接進(jìn)to 所指路由 next(false) //中斷當(dāng)前路由 next('route') //跳轉(zhuǎn)指定路由 next('error') //跳轉(zhuǎn)錯誤路由
beforeEach
實現(xiàn)用戶驗證的代碼:
router.beforeEach((to, from, next) => { ? ? ? //我在這里模仿了一個獲取用戶信息的方法 ? ?let isLogin = window.sessionStorage.getItem('userInfo'); ? ? ? if (isLogin) { ? ? ? ? ? //如果用戶信息存在則往下執(zhí)行。 ? ? ? ? ? next() ? ? ? } else { ? ? ? ? ? //如果用戶token不存在則跳轉(zhuǎn)到login頁面 ? ? ? ? ? if (to.path === '/login') { ? ? ? ? ? ? ?next() ? ? ? ? ?} else { ? ? ? ? ? ? ?next('/login') ? ? ? ? ?} ? ? ?}? ?})
afterEach
和 beforeEach 不同的是 afterEach 不接收第三個參數(shù) next 函數(shù),也不會改變導(dǎo)航本身,一般 beforeEach 用的最多,afterEach 用的少
router.afterEach((to,from)=>{ //這里不接收next ? ? console.log(to); ? ? console.log(from); })
全局導(dǎo)航守衛(wèi)是干什么的?
應(yīng)用場景: 登錄頁面防止用戶頁面直接在地址欄中可以訪問其他頁面;
背景: 在 地址欄當(dāng)中輸入地址可以訪問其他頁面;然而我們需要一個系統(tǒng)當(dāng)中來進(jìn)行攔截;
那就是全局導(dǎo)航守衛(wèi)來進(jìn)行攔截, 用vue-Router 實例的方法來實現(xiàn)的;
1.在router中的index.js文件里引入vue-router
import Router from 'vue-router' Vue.use(Router)
2.創(chuàng)建路由實例
const router = new Router({ routes: [ { path: '/', redirect: '/login' }, { path: '/login', component: Login }, { path: '/home', component: Home} ] })
3.掛載全局導(dǎo)航守衛(wèi)
//全局路由前置守衛(wèi) --路由攔截 router.beforeEach((to, from, next) => { // to 將要前往的路由 //from 從哪個路由過來的 //next(path) 是一個函數(shù) 表示繼續(xù)執(zhí)行下一步,強(qiáng)制執(zhí)行前往的path 路由 //如果前往login 頁面 則不需要token 直接進(jìn)入就可以 if (to.path === "/login") return next(); //獲取token const TOKEN = window.sessionStorage.getItem("TOKEN"); if (!TOKEN) { //token 不存在 name 意味著 沒有進(jìn)行登錄 返回登錄頁面 next({ path: "/login" }); } //已經(jīng) 存在TOKEN name 就可以進(jìn)行 next(); });
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
element tree懶加載:load="loadNode"只觸發(fā)一次的解決方案
本文主要介紹了element tree懶加載:load="loadNode"只觸發(fā)一次的解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08關(guān)于net?6+vue?插件axios?后端接收參數(shù)問題
接到這樣一個項目需求是這樣的,前端vue?必須對象傳遞后端也必須對象接收,接下來通過本文給大家介紹下net?6+vue?插件axios?后端接收參數(shù)的問題,需要的朋友可以參考下2022-01-01Vue-router優(yōu)化import引入過多導(dǎo)致index文件臃腫問題
這篇文章主要為大家介紹了Vue-router優(yōu)化import引入過多導(dǎo)致index文件臃腫問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Vue 使用v-model實現(xiàn)控制子組件顯隱效果
v-model 可以實現(xiàn)雙向綁定的效果,允許父組件控制子組件的顯示/隱藏,同時允許子組件自己控制自身的顯示/隱藏,本文給大介紹Vue 使用v-model實現(xiàn)控制子組件顯隱,感興趣的朋友一起看看吧2023-11-11el-select自定義指令實現(xiàn)觸底加載分頁請求options數(shù)據(jù)(完整代碼和接口可直接用)
某些情況下,下拉框需要做觸底加載,發(fā)請求,獲取option的數(shù)據(jù),下面給大家分享el-select自定義指令實現(xiàn)觸底加載分頁請求options數(shù)據(jù)(附上完整代碼和接口可直接用),感興趣的朋友參考下吧2024-02-02webstorm提示?@路徑?Module?is?not?installed的問題
這篇文章主要介紹了webstorm提示?@路徑?Module?is?not?installed的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11vue獲取當(dāng)前日期時間(使用moment和new?Date())
在項目開發(fā)中我遇到了日期范圍選擇器,兩種獲取當(dāng)前日期并做處理的寫法,這里記錄一下,下面這篇文章主要給大家介紹了關(guān)于vue獲取當(dāng)前日期時間(使用moment和new?Date())的相關(guān)資料,需要的朋友可以參考下2023-06-06