vue路由實(shí)現(xiàn)登錄攔截
一、概述
在項(xiàng)目開(kāi)發(fā)中每一次路由的切換或者頁(yè)面的刷新都需要判斷用戶是否已經(jīng)登錄,前端可以判斷,后端也會(huì)進(jìn)行判斷的,我們前端最好也進(jìn)行判斷。
vue-router提供了導(dǎo)航鉤子:全局前置導(dǎo)航鉤子 beforeEach和全局后置導(dǎo)航鉤子 afterEach,他們會(huì)在路由即將改變前和改變后進(jìn)行觸發(fā)。所以判斷用戶是否登錄需要在beforeEach導(dǎo)航鉤子中進(jìn)行判斷。
導(dǎo)航鉤子有3個(gè)參數(shù):
1、to:即將要進(jìn)入的目標(biāo)路由對(duì)象;
2、from:當(dāng)前導(dǎo)航即將要離開(kāi)的路由對(duì)象;
3、next :調(diào)用該方法后,才能進(jìn)入下一個(gè)鉤子函數(shù)(afterEach)。
next()//直接進(jìn)to 所指路由
next(false) //中斷當(dāng)前路由
next('route') //跳轉(zhuǎn)指定路由
next('error') //跳轉(zhuǎn)錯(cuò)誤路由
二、路由導(dǎo)航守衛(wèi)實(shí)現(xiàn)登錄攔截
這里用一個(gè)空白的vue項(xiàng)目來(lái)演示一下,主要有2個(gè)頁(yè)面,分別是首頁(yè)和登錄。
訪問(wèn)首頁(yè)時(shí),必須要登錄,否則跳轉(zhuǎn)到登錄頁(yè)面。
新建一個(gè)空白的vue項(xiàng)目,在src\components創(chuàng)建Login.vue
<template> <div>這是登錄頁(yè)面</div> </template> <script> export default { name: "Login" } </script> <style scoped> </style>
修改src\router\index.js
import Vue from 'vue' import Router from 'vue-router' import HelloWorld from '@/components/HelloWorld' import Login from '@/components/Login' Vue.use(Router) const router = new Router({ mode: 'history', //去掉url中的# routes: [ { path: '/login', name: 'login', meta: { title: '登錄', requiresAuth: false, // false表示不需要登錄 }, component: Login }, { path: '/', name: 'HelloWorld', meta: { title: '首頁(yè)', requiresAuth: true, // true表示需要登錄 }, component: HelloWorld }, ] }) // 路由攔截,判斷是否需要登錄 router.beforeEach((to, from, next) => { if (to.meta.title) { //判斷是否有標(biāo)題 document.title = to.meta.title; } // console.log("title",document.title) // 通過(guò)requiresAuth判斷當(dāng)前路由導(dǎo)航是否需要登錄 if (to.matched.some(record => record.meta.requiresAuth)) { let token = localStorage.getItem('token') // console.log("token",token) // 若需要登錄訪問(wèn),檢查是否為登錄狀態(tài) if (!token) { next({ path: '/login', query: { redirect: to.fullPath } }) } else { next() } } else { next() // 確保一定要調(diào)用 next() } }) export default router;
說(shuō)明:
在每一個(gè)路由中,加入了meta。其中requiresAuth字段,用來(lái)標(biāo)識(shí)是否需要登錄。
在router.beforeEach中,做了token判斷,為空時(shí),跳轉(zhuǎn)到登錄頁(yè)面。
訪問(wèn)首頁(yè)
http://localhost:8080
會(huì)跳轉(zhuǎn)到
http://localhost:8080/login?redirect=%2F
效果如下:
打開(kāi)F12,進(jìn)入console,手動(dòng)寫(xiě)入一個(gè)token
localStorage.setItem('token', '12345678910')
效果如下:
再次訪問(wèn)首頁(yè),就可以正常訪問(wèn)了。
打開(kāi)Application,刪除Local Storage里面的值,右鍵,點(diǎn)擊Clear即可
刷新頁(yè)面,就會(huì)跳轉(zhuǎn)到登錄頁(yè)面。
怎么樣,是不是很簡(jiǎn)單呢!
以上就是vue路由實(shí)現(xiàn)登錄攔截的詳細(xì)內(nèi)容,更多關(guān)于vue 登錄攔截的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue3.0+element表格獲取每行數(shù)據(jù)代碼示例
這篇文章主要給大家介紹了關(guān)于vue3.0+element表格獲取每行數(shù)據(jù)的相關(guān)資料,在element-ui中,你可以通過(guò)為表格的行綁定單擊事件來(lái)獲取表格中的一行數(shù)據(jù),需要的朋友可以參考下2023-09-09淺談webpack SplitChunksPlugin實(shí)用指南
這篇文章主要介紹了淺談webpack SplitChunksPlugin實(shí)用指南,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09vuex實(shí)現(xiàn)購(gòu)物車(chē)的增加減少移除
這篇文章主要為大家詳細(xì)介紹了vuex實(shí)現(xiàn)購(gòu)物車(chē)的增加減少移除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06vue 監(jiān)聽(tīng)窗口變化對(duì)頁(yè)面部分元素重新渲染操作
這篇文章主要介紹了vue 監(jiān)聽(tīng)窗口變化對(duì)頁(yè)面部分元素重新渲染操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07Vue3中watch監(jiān)聽(tīng)對(duì)象的屬性值(監(jiān)聽(tīng)源必須是一個(gè)getter函數(shù))
這篇文章主要介紹了Vue3中watch監(jiān)聽(tīng)對(duì)象的屬性值,監(jiān)聽(tīng)源必須是一個(gè)getter函數(shù),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12解決項(xiàng)目vite1.0升級(jí)到2.0打包遇到Some chunks are larger問(wèn)題
本文主要介紹了解決項(xiàng)目vite1.0升級(jí)到2.0打包遇到Some chunks are larger問(wèn)題,文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03Vue利用AJAX請(qǐng)求獲取XML文件數(shù)據(jù)的操作方法
在現(xiàn)代Web開(kāi)發(fā)中,從前端框架到后端API的交互是必不可少的一部分,Vue.js作為一個(gè)輕量級(jí)且功能強(qiáng)大的前端框架,支持多種方式與服務(wù)器通信,從而獲取或發(fā)送數(shù)據(jù),本文將詳細(xì)介紹如何在Vue.js項(xiàng)目中使用AJAX請(qǐng)求來(lái)獲取XML格式的數(shù)據(jù),需要的朋友可以參考下2024-09-09Vue?+?element-ui?背景圖片設(shè)置方式
這篇文章主要介紹了Vue?+?element-ui?背景圖片設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08