您好,登錄后才能下訂單哦!
這篇“vue路由守衛(wèi)及路由守衛(wèi)無(wú)限循環(huán)問(wèn)題怎么解決”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“vue路由守衛(wèi)及路由守衛(wèi)無(wú)限循環(huán)問(wèn)題怎么解決”文章吧。
先貼一波官方文檔的內(nèi)容
const router = new VueRouter({ ... }) router.beforeEach((to, from, next) => { // ... })
當(dāng)一個(gè)導(dǎo)航觸發(fā)時(shí),全局前置守衛(wèi)按照創(chuàng)建順序調(diào)用。守衛(wèi)是異步解析執(zhí)行,此時(shí)導(dǎo)航在所有守衛(wèi) resolve 完之前一直處于 等待中。
每個(gè)守衛(wèi)方法接收三個(gè)參數(shù):
to: Route: 即將要進(jìn)入的目標(biāo) 路由對(duì)象
from: Route: 當(dāng)前導(dǎo)航正要離開的路由
next: Function: 一定要調(diào)用該方法來(lái) resolve 這個(gè)鉤子。執(zhí)行效果依賴 next 方法的調(diào)用參數(shù)。
next(): 進(jìn)行管道中的下一個(gè)鉤子。如果全部鉤子執(zhí)行完了,則導(dǎo)航的狀態(tài)就是 confirmed (確認(rèn)的)。
next(false): 中斷當(dāng)前的導(dǎo)航。如果瀏覽器的 URL 改變了 (可能是用戶手動(dòng)或者瀏覽器后退按鈕),那么 URL 地址會(huì)重置到 from 路由對(duì)應(yīng)的地址。
next('/') 或者 next({ path: '/' }): 跳轉(zhuǎn)到一個(gè)不同的地址。當(dāng)前的導(dǎo)航被中斷,然后進(jìn)行一個(gè)新的導(dǎo)航。你可以向 next 傳遞任意位置對(duì)象,且允許設(shè)置諸如 replace: true、name: 'home' 之類的選項(xiàng)以及任何用在 router-link 的 to prop 或 router.push 中的選項(xiàng)。
next(error): (2.4.0+) 如果傳入 next 的參數(shù)是一個(gè) Error 實(shí)例,則導(dǎo)航會(huì)被終止且該錯(cuò)誤會(huì)被傳遞給 router.onError() 注冊(cè)過(guò)的回調(diào)。確保要調(diào)用 next 方法,否則鉤子就不會(huì)被 resolved
然后這是我自己的總結(jié)
import Vue from 'vue' import Router from 'vue-router' import Login from '@/pages/login/Login' import Index from '../pages/index/Index' import Library from '../pages/library/Library' import Design from '../pages/design/Design' import Administration from '../pages/administration/Administration' import Production from '../pages/production/Production' import Global from '../common/global/Global' Vue.use(Router) const router = new Router({ routes: [ { path: '/', name: 'login', component: Login }, { path: '/index', name: 'index', component: Index }, { path: '/library', name: 'library', component: Library }, { path: '/design', name: 'design', component: Design }, { path: '/administration', name: 'administration', component: Administration }, { path: '/production', name: 'production', component: Production } ] }) router.beforeEach ((to,from,next) => { //將所有需要登陸才顯示的頁(yè)面的路由都放進(jìn)一個(gè)數(shù)組 const nextRoute = ['index', 'library', 'design', 'administration', 'production']; //獲取登陸狀態(tài) let isLogin = Global.isLogin if(to.name === 'login') { //如果是登錄頁(yè),則跳過(guò)驗(yàn)證 next() //必不可少 return //以下的代碼不執(zhí)行 } if(nextRoute.indexOf(to.name) >= 0) { //判斷該頁(yè)面是否需要登陸 if(!isLogin) { //判斷登陸狀態(tài) next({ name : 'login'}) //如果未登錄,則跳轉(zhuǎn)到登錄頁(yè) } else { next() //如果已經(jīng)登陸,那就可以跳轉(zhuǎn) } } else { //其他的無(wú)需登陸的頁(yè)面不做驗(yàn)證 next() } }) export default router
這樣就實(shí)現(xiàn)了全局路由守衛(wèi)
關(guān)于路由守衛(wèi)無(wú)限循環(huán)問(wèn)題
如果你的代碼是這樣
if(isLogin) { next() } else { next({ name: 'login')} }
這樣的話就會(huì)陷入無(wú)限循環(huán)
因?yàn)槟愕?nbsp; next({ name: 'login')} 是相當(dāng)于一個(gè)路由跳轉(zhuǎn),它會(huì)再次觸發(fā)全局路由守衛(wèi),你又進(jìn)入了全局路由守衛(wèi)進(jìn)行再次判斷,如此循環(huán)。
所以,想要結(jié)束路由守衛(wèi),整段代碼的邏輯必須由 next() 進(jìn)行結(jié)尾。比如像我上面寫的,當(dāng)需要進(jìn)入登錄頁(yè)的時(shí)候,
if(to.name === 'login') { next() return }
加上這個(gè)判斷,當(dāng)你進(jìn)入登錄頁(yè)的時(shí)候也會(huì)調(diào)用next() , 路由守衛(wèi)進(jìn)入確認(rèn)狀態(tài),路由才會(huì)進(jìn)行跳轉(zhuǎn)。
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫(kù)只關(guān)注視圖層,方便與第三方庫(kù)和項(xiàng)目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫(kù)開發(fā)復(fù)雜的單頁(yè)應(yīng)用。
以上就是關(guān)于“vue路由守衛(wèi)及路由守衛(wèi)無(wú)限循環(huán)問(wèn)題怎么解決”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。