溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue導(dǎo)航守衛(wèi)怎么使用

發(fā)布時(shí)間:2023-04-11 15:24:28 來源:億速云 閱讀:95 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Vue導(dǎo)航守衛(wèi)怎么使用”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“Vue導(dǎo)航守衛(wèi)怎么使用”文章能幫助大家解決問題。

守衛(wèi)參數(shù)

  • to: 即將要進(jìn)入的目標(biāo)路由

  • from: 當(dāng)前導(dǎo)航即將要離開的路由

  • next(可選): 不傳參默認(rèn)去to路由,傳參可改變目標(biāo)路由

注意:可以向任意給定的導(dǎo)航守衛(wèi)傳遞next,但是next的使用過程容易出錯(cuò),需要確保next在任何給定的導(dǎo)航守衛(wèi)中都被嚴(yán)格調(diào)用一次。(可以出現(xiàn)多于一次,但是只能在所有邏輯路徑都不重疊的情況,否則鉤子永遠(yuǎn)不會(huì)被解析或者報(bào)錯(cuò))

守衛(wèi)返回值

  • false: 取消當(dāng)前導(dǎo)航

  • 路由地址:導(dǎo)航中斷,跳轉(zhuǎn)到返回的路由地址。(例如:return {name:‘login’}跳轉(zhuǎn)到登陸頁)

  • undefined/true: 導(dǎo)航有效,調(diào)用下一個(gè)導(dǎo)航守衛(wèi)

  • 注意:如果有錯(cuò)誤,會(huì)取消導(dǎo)航并調(diào)用router.onError()

全局守衛(wèi)

全局前置守衛(wèi)

const router = createRouter({...})
router.beforeEach((to, from) => {
})
  • 導(dǎo)航觸發(fā)時(shí),全局前置守衛(wèi)按照創(chuàng)建順序調(diào)用

  • 守衛(wèi)是異步解析執(zhí)行,導(dǎo)航在所有守衛(wèi)resolve完之前一直處于等待

全局解析守衛(wèi)

router.beforeResolve(async to => {
})
  • 在導(dǎo)航被確認(rèn)之前,在所有組件內(nèi)守衛(wèi)和異步路由組件被解析之后調(diào)用

  • 是獲取數(shù)據(jù)或避免用戶無法進(jìn)入頁面時(shí)執(zhí)行操作的理想位置

全局后置鉤子

router.afterEach((to, from) => {
})
  • 和守衛(wèi)的區(qū)別:不會(huì)接收next函數(shù),也不會(huì)改變導(dǎo)航

  • 作用:分析/更改頁面標(biāo)題,聲明頁面等

單個(gè)路由獨(dú)享守衛(wèi)

const routes = [{
    path: '/users/:id',
    component: UserDetails,
    beforeEnter: (to, from) => {
    },
    // beforeEnter: [removeQuery, removeHash]
}]
  • 只在進(jìn)入路由時(shí)觸發(fā),不會(huì)在params/query/hash改變時(shí)觸發(fā)(如:/user/1 -> /user/2)

  • 傳參:可以傳遞函數(shù)數(shù)組,有利于重用守衛(wèi)

組件級(jí)守衛(wèi)

  • beforeRouteEnter: 在渲染該組件對(duì)應(yīng)路由被驗(yàn)證前調(diào)用,不能獲取this

  • beforeRouteUpdate: 在組件被復(fù)用時(shí)調(diào)用,可以訪問this

  • beforeRouteLeave: 在導(dǎo)航離開該組件路由時(shí)調(diào)用,可以訪問this

注意:beforeRouteEnter 是支持給 next 傳遞回調(diào)的唯一守衛(wèi)

beforeRouteEnter(to, from, next) {
    next(vm => {
        // 通過'vm'訪問組件實(shí)例
    })
}

離開守衛(wèi):通常用來預(yù)防用戶在還未保存修改前突然離開,可以通過返回false來取消

完整的導(dǎo)航解析流程

  1. 導(dǎo)航被觸發(fā)

  2. 在離開的組件里調(diào)用 beforeRouteLeave 守衛(wèi)

  3. 調(diào)用全局的 beforeEach 守衛(wèi)

  4. (如果是重用組件)調(diào)用 beforeRouteUpdate 守衛(wèi)

  5. 在路由配置里調(diào)用 beforeEnter

  6. 解析異步路由組件

  7. 在被激活的組件里調(diào)用 beforeRouteEnter

  8. 調(diào)用全局的 beforeResolve 守衛(wèi)

  9. 導(dǎo)航被確認(rèn)

  10. 調(diào)用全局的 afterEach 鉤子

  11. 觸發(fā) DOM 更新

  12. 調(diào)用 beforeRouteEnter 守衛(wèi)中傳給 next 的回調(diào)函數(shù),創(chuàng)建好的組件實(shí)例會(huì)作為回調(diào)函數(shù)的參數(shù)傳入

關(guān)于“Vue導(dǎo)航守衛(wèi)怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI