欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue路由守衛(wèi)詳解

 更新時間:2023年10月20日 09:19:49   作者:內(nèi)師-ZT  
路由導(dǎo)航守衛(wèi)提供了一些鉤子函數(shù),可以在路由導(dǎo)航過程中進(jìn)行攔截和控制,其中,beforeEach 導(dǎo)航守衛(wèi)可以在每次路由切換前被觸發(fā),本文給大家介紹Vue路由守衛(wèi)詳解,感興趣的朋友一起看看吧

什么是路由守衛(wèi)

路由守衛(wèi)是Vue Router提供的一種機(jī)制,用于在導(dǎo)航過程中對路由進(jìn)行控制和管理。通過使用路由守衛(wèi),你可以在路由切換前、切換后以及錯誤處理時執(zhí)行相應(yīng)的邏輯。

Vue Router提供了三種類型的路由守衛(wèi):
1、全局前置守衛(wèi)
2、路由獨享的守衛(wèi)
3、組件內(nèi)的守衛(wèi)

全局前置守衛(wèi)

全局前置守衛(wèi)( router.beforeEach):這些守衛(wèi)會在路由切換之前被調(diào)用,可以用來進(jìn)行權(quán)限驗證、登錄狀態(tài)檢查等操作。常見的全局前置守衛(wèi)有beforeEach。

語法

router.beforeEach((to, from, next) => {
  // 在每次路由導(dǎo)航觸發(fā)前執(zhí)行的邏輯  
});

在router/index.js中的具體配置

// index.js
import Vue from 'vue';
import VueRouter from 'vue-router';
Vue.use(VueRouter);
const router = new VueRouter({
  // 路由配置
  routes: [
    // ...定義路由...
  ]
});
router.beforeEach((to, from, next) => {
  // 全局前置守衛(wèi)邏輯
});
export default router;

在上述示例中,我們通過 router.beforeEach 方法注冊了一個全局前置守衛(wèi)。在每次路由導(dǎo)航之前,該守衛(wèi)會被調(diào)用。守衛(wèi)的回調(diào)函數(shù)接收三個參數(shù):

  • to:即將跳轉(zhuǎn)的目標(biāo)路由對象
  • from:當(dāng)前導(dǎo)航正要離開的路由對象
  • next:用于控制導(dǎo)航行為的回調(diào)函數(shù)

在守衛(wèi)的回調(diào)函數(shù)中,你可以根據(jù)業(yè)務(wù)需求執(zhí)行相應(yīng)的操作,如驗證用戶權(quán)限、檢查登錄狀態(tài)、取消導(dǎo)航或重定向到其他路由。next 函數(shù)用于控制導(dǎo)航的繼續(xù)或中斷。

  • 若要中斷當(dāng)前導(dǎo)航并取消跳轉(zhuǎn),可以調(diào)用 next(false)。
  • 若要重定向到其他路由,并且希望中斷當(dāng)前導(dǎo)航,可以調(diào)用 next('/other-route')
  • 若無需中斷導(dǎo)航,則調(diào)用 next() 允許導(dǎo)航繼續(xù)。

全局前置守衛(wèi)(Global before Guards)可以在以下場景中發(fā)揮作用:

  • 登錄驗證:你可以使用全局前置守衛(wèi)來驗證用戶是否已登錄。通過檢查用戶的登錄狀態(tài)或者驗證用戶的身份信息,可以防止未經(jīng)授權(quán)的用戶訪問需要登錄權(quán)限的頁面。
  • 權(quán)限控制:全局前置守衛(wèi)可以用于實現(xiàn)基于角色或權(quán)限的訪問控制。通過在守衛(wèi)中檢查用戶的角色或權(quán)限,可以限制用戶只能訪問其具備權(quán)限的頁面,并在沒有權(quán)限時進(jìn)行相應(yīng)的處理,如跳轉(zhuǎn)到錯誤頁面或提示無權(quán)限信息。
  • 路由攔截:在進(jìn)行路由導(dǎo)航之前,你可以使用全局前置守衛(wèi)來攔截、修改或重定向?qū)Ш?。根?jù)特定的條件或業(yè)務(wù)需求,你可以在守衛(wèi)中對導(dǎo)航進(jìn)行處理,如取消導(dǎo)航、修改目標(biāo)路由或跳轉(zhuǎn)到其他頁面。
  • 數(shù)據(jù)預(yù)處理:有時,在進(jìn)入某個路由之前,你可能需要對相關(guān)數(shù)據(jù)進(jìn)行加載、初始化或驗證等操作。全局前置守衛(wèi)可以幫助你在導(dǎo)航發(fā)生前執(zhí)行這些預(yù)處理任務(wù),確保數(shù)據(jù)的準(zhǔn)備工作完成后再進(jìn)入目標(biāo)路由。

路由獨享的守衛(wèi)

路由獨享的守衛(wèi)(beforeEnter):這些守衛(wèi)可以直接在路由配置中定義,只對特定的路由生效??梢栽谶M(jìn)入該路由前、離開該路由前或兩者之間執(zhí)行相應(yīng)邏輯。常見的路由獨享守衛(wèi)有beforeEnter。

語法

const router = new VueRouter({
  routes: [
    {
      path: '/example',//具體跳轉(zhuǎn)路徑
      component: ExampleComponent,//具體跳轉(zhuǎn)頁面
      beforeEnter: (to, from, next) => {
        // 在單個路由的獨享守衛(wèi)邏輯
      }
    },
    // ...
  ]
});

在router/index.js中的具體配置

// index.js
import Vue from 'vue';
import VueRouter from 'vue-router';
Vue.use(VueRouter);
const routes = [
  {
    path: '/example',
    component: ExampleComponent,
    beforeEnter: (to, from, next) => {
      // 在單個路由的獨享守衛(wèi)邏輯
    }
  },
  // ...其他路由配置...
];
const router = new VueRouter({
  routes
});
export default router;

路由獨享的守衛(wèi)在以下場景中非常有用:

  • 鑒權(quán)和權(quán)限控制:你可以使用路由獨享的守衛(wèi)來驗證用戶的身份和權(quán)限。例如,對于需要登錄才能訪問的特定路由,可以在其獨享守衛(wèi)中檢查用戶是否已經(jīng)登錄,如果未登錄則阻止導(dǎo)航到該路由。
  • 數(shù)據(jù)加載和處理:有時候,在進(jìn)入某個路由之前需要先加載一些數(shù)據(jù)或執(zhí)行一些異步操作。在路由獨享的守衛(wèi)中,你可以調(diào)用 API 請求數(shù)據(jù),確保數(shù)據(jù)加載完畢后再繼續(xù)導(dǎo)航到目標(biāo)路由。
  • 導(dǎo)航控制:某些情況下,你可能希望根據(jù)一定條件來控制導(dǎo)航行為,如取消導(dǎo)航、重定向到其他路由等。通過在路由獨享的守衛(wèi)中進(jìn)行條件判斷,并調(diào)用適當(dāng)?shù)膶?dǎo)航方法,可以實現(xiàn)對導(dǎo)航行為的精確控制。
  • 日志記錄或埋點:如果你需要在特定的路由上進(jìn)行日志記錄或進(jìn)行統(tǒng)計分析,可以使用路由獨享的守衛(wèi)來觸發(fā)相應(yīng)的操作。例如,在進(jìn)入某個路由時記錄訪問日志或發(fā)送統(tǒng)計數(shù)據(jù)。

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

組件內(nèi)的守衛(wèi):這些守衛(wèi)是直接寫在組件內(nèi)部的方法,用于對組件內(nèi)部的路由變化做出反應(yīng)。常見的組件內(nèi)守衛(wèi)有beforeRouteEnter、beforeRouteUpdate和beforeRouteLeave。

組件內(nèi)的守衛(wèi)允許你在組件內(nèi)部針對組件生命周期的不同階段執(zhí)行相應(yīng)的邏輯。

以下是Vue.js提供的組件內(nèi)的守衛(wèi):

  • beforeRouteEnter:在進(jìn)入路由前被調(diào)用,但在組件實例被創(chuàng)建之前被調(diào)用,因此無法訪問組件實例??梢酝ㄟ^傳入一個回調(diào)來獲取組件實例或使用Promise來延遲進(jìn)入。
  • beforeRouteLeave:在離開當(dāng)前路由時被調(diào)用??梢杂糜诖_認(rèn)是否離開頁面、保存臨時數(shù)據(jù)等操作。
  • beforeRouteUpdate:在當(dāng)前路由被復(fù)用時被調(diào)用,即參數(shù)發(fā)生變化但是組件實例仍然被復(fù)用??梢栽谠撌匦l(wèi)中對參數(shù)的變化作出響應(yīng)。

這些守衛(wèi)可以直接定義在組件的選項中
語法

export default {
  // ...
  beforeRouteEnter(to, from, next) {
    // 在組件實例創(chuàng)建之前調(diào)用
    // 可以使用回調(diào)函數(shù)或返回一個Promise延遲進(jìn)入
  },
  beforeRouteLeave(to, from, next) {
    // 在離開當(dāng)前路由時調(diào)用
    // 可以進(jìn)行確認(rèn)、保存數(shù)據(jù)等操作
  },
  beforeRouteUpdate(to, from, next) {
    // 在當(dāng)前路由被復(fù)用時調(diào)用
    // 可以對參數(shù)的變化作出響應(yīng)
  }
  // ...
}

組件內(nèi)的守衛(wèi)在以下場景中非常有用:

  • 驗證用戶身份:在進(jìn)入某個路由前,可以通過 beforeRouteEnter 守衛(wèi)驗證用戶的登錄狀態(tài)或權(quán)限。如果用戶未登錄或沒有足夠的權(quán)限訪問該路由,可以取消導(dǎo)航或重定向到其他頁面。
  • 加載異步數(shù)據(jù):在進(jìn)入某個路由前,可以使用 beforeRouteEnter 守衛(wèi)獲取異步數(shù)據(jù),并在數(shù)據(jù)加載完成后再渲染組件。這樣可以確保組件在數(shù)據(jù)加載完成后才會顯示,避免因數(shù)據(jù)未加載完成而出現(xiàn)顯示問題。
  • 取消導(dǎo)航:在離開當(dāng)前路由前,可以使用 beforeRouteLeave 守衛(wèi)進(jìn)行一些判斷和操作,例如檢查表單是否被修改過,詢問用戶是否需要保存未提交的數(shù)據(jù)。根據(jù)用戶的選擇,可以取消導(dǎo)航或繼續(xù)進(jìn)行下一個路由。
  • 條件渲染和動態(tài)路由:在 beforeRouteUpdate 守衛(wèi)中,可以根據(jù)當(dāng)前路由參數(shù)的變化,更新組件的數(shù)據(jù)或重新請求數(shù)據(jù)。這樣可以實現(xiàn)根據(jù)不同的路由參數(shù)動態(tài)展示內(nèi)容或刷新組件的狀態(tài)。

舉例說明

在 Vue 開發(fā)中,你可以通過路由導(dǎo)航守衛(wèi)來實現(xiàn)在未登錄狀態(tài)下先展示登錄頁面而不展示首頁。

路由導(dǎo)航守衛(wèi)提供了一些鉤子函數(shù),可以在路由導(dǎo)航過程中進(jìn)行攔截和控制。其中,beforeEach 導(dǎo)航守衛(wèi)可以在每次路由切換前被觸發(fā)。

使用路由導(dǎo)航守衛(wèi)來實現(xiàn)在未登錄狀態(tài)下先展示登錄頁面:

// main.js
import Vue from 'vue';
import App from './App.vue';
import router from './router';
// 全局的路由導(dǎo)航守衛(wèi)
router.beforeEach((to, from, next) => {
  const isLoggedIn = checkUserLoggedIn(); // 根據(jù)實際情況判斷用戶是否已登錄
  if (to.path !== '/login' && !isLoggedIn) {
    // 如果用戶未登錄且訪問的不是登錄頁,則重定向到登錄頁
    next('/login');
  } else {
    // 已登錄或者訪問的是登錄頁,則正常跳轉(zhuǎn)
    next();
  }
});
new Vue({
  router,
  render: (h) => h(App)
}).$mount('#app');

上述代碼中,我們在 beforeEach 導(dǎo)航守衛(wèi)中進(jìn)行判斷,如果用戶未登錄且訪問的不是登錄頁(即非 /login 路徑),則使用 next('/login') 將用戶重定向到登錄頁;否則,如果用戶已登錄或者訪問的是登錄頁,則繼續(xù)正常跳轉(zhuǎn)。

這樣,在每次路由切換之前都會進(jìn)行登錄狀態(tài)的檢查,并根據(jù)檢查結(jié)果來決定是否重定向到登錄頁。這樣就可以先展示登錄頁而不先展示首頁。

當(dāng)用戶訪問其他需要登錄才能查看的頁面時,會被攔截并跳轉(zhuǎn)到登錄頁面。用戶在登錄成功之后,再跳轉(zhuǎn)到原本要訪問的頁面。

請注意,checkUserLoggedIn() 是一個自定義函數(shù),用于實際判斷用戶是否已登錄,請根據(jù)你的實際需求和認(rèn)證邏輯來編寫該函數(shù)。

到此這篇關(guān)于Vue路由守衛(wèi)詳解的文章就介紹到這了,更多相關(guān)Vue路由守衛(wèi)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vuex存儲token示例

    vuex存儲token示例

    今天小編就為大家分享一篇vuex存儲token示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue+element導(dǎo)航欄高亮顯示的解決方式

    vue+element導(dǎo)航欄高亮顯示的解決方式

    今天小編就為大家分享一篇vue+element導(dǎo)航欄高亮顯示的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue+element實現(xiàn)批量刪除功能的示例

    vue+element實現(xiàn)批量刪除功能的示例

    下面小編就為大家分享一篇vue+element實現(xiàn)批量刪除功能的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • vue-cli構(gòu)建項目使用 less的方法

    vue-cli構(gòu)建項目使用 less的方法

    這篇文章主要介紹了vue-cli構(gòu)建項目使用 less,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • Element el-table 表格使用詳解

    Element el-table 表格使用詳解

    我們的數(shù)據(jù)存儲到數(shù)據(jù)庫,不就是以表格的形式存在嗎,所以在界面上顯示、操作,使用表格來處理也是非常合理的,這篇文章給大家介紹Element el-table 表格使用方法,感興趣的朋友一起看看吧
    2024-03-03
  • vue.js樣式布局Flutter業(yè)務(wù)開發(fā)常用技巧

    vue.js樣式布局Flutter業(yè)務(wù)開發(fā)常用技巧

    這篇文章主要為大家介紹了vue.js樣式布局Flutter業(yè)務(wù)開發(fā)中的常用技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2021-11-11
  • Vue2.0 多 Tab切換組件的封裝實例

    Vue2.0 多 Tab切換組件的封裝實例

    本篇文章主要介紹了Vue2.0 多 Tab切換組件的封裝實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Vue解決ajax跨域的問題

    Vue解決ajax跨域的問題

    這篇文章主要介紹了Vue解決ajax跨域的問題,跨域請求:是指協(xié)議名、主機(jī)名、端口號三者有任何一個不一樣,而且跨域請求是請求發(fā)出去了,服務(wù)器接收并返回了結(jié)果,只是瀏覽器沒有接收響應(yīng)結(jié)果。感興趣的同學(xué)可以參考閱讀
    2023-04-04
  • 詳解vue?Router(v3.x)?路由傳參的三種方式

    詳解vue?Router(v3.x)?路由傳參的三種方式

    vue路由傳參的使用場景一般都是應(yīng)用在父路由跳轉(zhuǎn)到子路由時,攜帶參數(shù)跳轉(zhuǎn),本文將詳細(xì)介紹vue路由傳參的三種方式,這三種傳參方式只是針對vue?Router?V3版本的,需要的朋友可以參考下
    2023-07-07
  • 如何搭建一個完整的Vue3.0+ts的項目步驟

    如何搭建一個完整的Vue3.0+ts的項目步驟

    這篇文章主要介紹了如何搭建一個完整的Vue3.0+ts的項目步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評論