米利唐_后腰_乌克兰足球超级联赛_中国竞彩欧赔 - 足球竞彩分析

集團(tuán)官網(wǎng)
  • 國(guó)家級(jí)全民數(shù)字素養(yǎng)與技能培訓(xùn)基地
  • 河南省第一批產(chǎn)教融合型企業(yè)建設(shè)培育單位
  • 鄭州市數(shù)字技能人才(碼農(nóng))培養(yǎng)評(píng)價(jià)聯(lián)盟

Vue路由守衛(wèi)有哪些,怎么設(shè)置,有哪些使用場(chǎng)景?

編輯:云和數(shù)據(jù) 日期:2023-05-17 09:42

Vue 路由守衛(wèi)是在 Vue Router 中提供的一種功能,它允許您在導(dǎo)航到某個(gè)路由前、路由變化時(shí)或?qū)Ш诫x開某個(gè)路由時(shí)執(zhí)行代碼。Vue 路由守衛(wèi)提供了以下幾種類型:

1.全局前置守衛(wèi)

router.beforeEach 在進(jìn)入路由前執(zhí)行的鉤子函數(shù),它會(huì)接收三個(gè)參數(shù):to(要進(jìn)入的路由對(duì)象)、from(當(dāng)前導(dǎo)航正要離開的路由對(duì)象)和 next(必須調(diào)用該函數(shù)才能進(jìn)入下一個(gè)鉤子)。

2.全局解析守衛(wèi)

router.beforeResolve 在路由解析之前執(zhí)行的鉤子函數(shù),也會(huì)接收 to、from 和 next 參數(shù)。與 beforeEach 的區(qū)別在于,該守衛(wèi)在全局守衛(wèi)中被最后調(diào)用,因此它在所有路由組件內(nèi)的守衛(wèi)和異步路由組件被解析之后才被調(diào)用。

3.全局后置鉤子

router.afterEach 在進(jìn)入路由后執(zhí)行的鉤子函數(shù),它不接收 next 函數(shù),也不能改變導(dǎo)航。

4.路由獨(dú)享守衛(wèi)

beforeEnter 在路由配置中定義的鉤子函數(shù),它會(huì)在路由被激活之前調(diào)用。它和全局前置守衛(wèi)的參數(shù)一樣,但是只對(duì)該路由生效。

5.組件內(nèi)的守衛(wèi)

·beforeRouteEnter:在路由進(jìn)入時(shí)異步加載組件前調(diào)用。

·beforeRouteUpdate:在當(dāng)前路由改變,但是該組件被復(fù)用時(shí)調(diào)用(例如,從 /users/1 導(dǎo)航到 /users/2 時(shí))。

·beforeRouteLeave:在離開當(dāng)前路由時(shí)調(diào)用。

要設(shè)置路由守衛(wèi),可以在路由實(shí)例的配置對(duì)象中添加相應(yīng)的屬性。例如,設(shè)置全局前置守衛(wèi)可以這樣寫:

const?router?=?new?VueRouter({??routes:?[...],})router.beforeEach((to,?from,?next)?=>?{??//?...})

使用場(chǎng)景包括但不限于:

1.驗(yàn)證用戶權(quán)限:在進(jìn)入某些頁(yè)面之前檢查用戶是否已登錄或是否有權(quán)限訪問該頁(yè)面。

2.加載數(shù)據(jù):在進(jìn)入頁(yè)面前加載必要的數(shù)據(jù),例如在組件內(nèi)使用 beforeRouteEnter 鉤子函數(shù)異步獲取數(shù)據(jù)。

3.路由重定向:在進(jìn)入某些頁(yè)面時(shí)需要重定向到另一個(gè)頁(yè)面,例如在全局前置守衛(wèi)中檢查用戶是否已登錄并將未登錄用戶重定向到登錄頁(yè)面。

4.路由攔截:在某些情況下需要取消路由導(dǎo)航,例如在組件內(nèi)使用 beforeRouteLeave 鉤子函數(shù)防止用戶誤操作離開當(dāng)前頁(yè)面。

相關(guān)內(nèi)容

搶先一步 鴻蒙(HarmonyOS)應(yīng)用開發(fā)者高級(jí)認(rèn)證 免費(fèi)考! 適合人群計(jì)算機(jī)相關(guān)專業(yè)在校生(技師、中職、高職、本科、研究生)對(duì)鴻蒙(HarmonyOS)有興趣的非計(jì)算機(jī)相關(guān)專業(yè)在校生目前正在從事移動(dòng)應(yīng)用的開發(fā)者目前正在從事計(jì)算機(jī)行業(yè)相關(guān)的人計(jì)算機(jī)專業(yè)高校老師所有對(duì)鴻蒙(HarmonyOS)有興趣的人 培訓(xùn)方案掌握鴻蒙的核心概念和端云一體化開發(fā)、... 什么是Java的多態(tài)性(polymorphism)?它有哪些不同的形式? 多態(tài)性是Java面向?qū)ο缶幊痰囊粋€(gè)重要概念,它允許不同的對(duì)象以一致的方式響應(yīng)同一個(gè)方法調(diào)用,具體表現(xiàn)為對(duì)象在運(yùn)行時(shí)可以表現(xiàn)出多個(gè)不同的形態(tài)。多態(tài)性主要有兩種不同的形式:編譯時(shí)多態(tài)性(靜態(tài)多態(tài)性)和運(yùn)行時(shí)多態(tài)性(動(dòng)態(tài)多態(tài)性)。1. 編譯時(shí)多態(tài)性(靜態(tài)多態(tài)性):   ... 如何學(xué)習(xí)和搭建Hadoop開發(fā)環(huán)境? Hadoop是大數(shù)據(jù)處理領(lǐng)域的重要平臺(tái),能夠處理和分析大量數(shù)據(jù)。為了有效地利用Hadoop,我們需要學(xué)習(xí)其基礎(chǔ)知識(shí),并正確搭建開發(fā)環(huán)境。下面是詳細(xì)的學(xué)習(xí)和搭建指南。一、學(xué)習(xí)Hadoop基礎(chǔ)掌握基礎(chǔ)概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統(tǒng),Ma... UI 設(shè)計(jì)學(xué)習(xí)如何進(jìn)階成為高手 我總結(jié)了六種方法,幫助你走出舒適區(qū),提高技能,成長(zhǎng)為自信且經(jīng)驗(yàn)豐富的UI設(shè)計(jì)高手一位經(jīng)驗(yàn)豐富的 UI 設(shè)計(jì)師,往往十分看中應(yīng)用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經(jīng)在 UI 設(shè)計(jì)圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因?yàn)橄萑肓艘粋€(gè)舒適圈,UI技能一直原... 在Java中Executor和Executors的區(qū)別? 在Java中,Executor和Executors都與線程池和并發(fā)執(zhí)行有關(guān),但它們是不同的概念和類。1.ExecutorExecutor是一個(gè)接口,位于java.util.concurrent包中,用于表示一個(gè)執(zhí)行任務(wù)的執(zhí)行器。它只定義了一個(gè)方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡(jiǎn)單的存儲(chǔ)類型。其value是字符串,不過根據(jù)字符串的格式不同,又可以分為3類:string是普通字符串,int整數(shù)類型,可以做自增、自減操作,float浮點(diǎn)類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經(jīng)存在的...