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

關(guān)于Vue中的全局導(dǎo)航守衛(wèi)(beforeEach、afterEach)

 更新時間:2022年07月28日 10:03:31   作者:YaaLee_  
這篇文章主要介紹了關(guān)于Vue中的全局導(dǎo)航守衛(wèi)(beforeEach、afterEach),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

全局導(dǎo)航守衛(wèi)(beforeEach、afterEach)

在項目開發(fā)中每一次路由的切換或者頁面的刷新都需要判斷用戶是否已經(jīng)登錄,前端可以判斷,后端也會進(jìn)行判斷的,我們前端最好也進(jìn)行判斷。

vue-router 提供了導(dǎo)航鉤子:全局前置導(dǎo)航鉤子 beforeEach 和全局后置導(dǎo)航鉤子 afterEach,他們會在路由即將改變前和改變后進(jìn)行觸發(fā)。所以判斷用戶是否登錄需要在 beforeEach 導(dǎo)航鉤子中進(jìn)行判斷。

導(dǎo)航鉤子有3個參數(shù)

1、to:即將要進(jìn)入的目標(biāo)路由對象;

2、from:當(dāng)前導(dǎo)航即將要離開的路由對象;

3、next :調(diào)用該方法后,才能進(jìn)入下一個鉤子函數(shù)(afterEach)。

next()//直接進(jìn)to 所指路由
next(false) //中斷當(dāng)前路由
next('route') //跳轉(zhuǎn)指定路由
next('error') //跳轉(zhuǎn)錯誤路由

beforeEach

實現(xiàn)用戶驗證的代碼:

router.beforeEach((to, from, next) => {
? ? ? //我在這里模仿了一個獲取用戶信息的方法
? ?let isLogin = window.sessionStorage.getItem('userInfo');
? ? ? if (isLogin) {
? ? ? ? ? //如果用戶信息存在則往下執(zhí)行。
? ? ? ? ? next()
? ? ? } else {
? ? ? ? ? //如果用戶token不存在則跳轉(zhuǎn)到login頁面
? ? ? ? ? if (to.path === '/login') {
? ? ? ? ? ? ?next()
? ? ? ? ?} else {
? ? ? ? ? ? ?next('/login')
? ? ? ? ?}
? ? ?}?
?})

afterEach

和 beforeEach 不同的是 afterEach 不接收第三個參數(shù) next 函數(shù),也不會改變導(dǎo)航本身,一般 beforeEach 用的最多,afterEach 用的少

router.afterEach((to,from)=>{ //這里不接收next
? ? console.log(to);
? ? console.log(from);
})

全局導(dǎo)航守衛(wèi)是干什么的?

應(yīng)用場景: 登錄頁面防止用戶頁面直接在地址欄中可以訪問其他頁面;

背景: 在 地址欄當(dāng)中輸入地址可以訪問其他頁面;然而我們需要一個系統(tǒng)當(dāng)中來進(jìn)行攔截;

那就是全局導(dǎo)航守衛(wèi)來進(jìn)行攔截, 用vue-Router 實例的方法來實現(xiàn)的;

1.在router中的index.js文件里引入vue-router

import Router from 'vue-router'
Vue.use(Router)

2.創(chuàng)建路由實例

const router = new Router({
  routes: [
    { path: '/', redirect: '/login' },
    { path: '/login', component: Login },
    { path: '/home', component: Home}
  ]
})

3.掛載全局導(dǎo)航守衛(wèi)

//全局路由前置守衛(wèi) --路由攔截
router.beforeEach((to, from, next) => {
  // to  將要前往的路由
  //from 從哪個路由過來的
  //next(path) 是一個函數(shù)  表示繼續(xù)執(zhí)行下一步,強(qiáng)制執(zhí)行前往的path 路由
 
  //如果前往login 頁面  則不需要token 直接進(jìn)入就可以
  if (to.path === "/login") return next();
 
  //獲取token
  const TOKEN = window.sessionStorage.getItem("TOKEN");
  if (!TOKEN) {
    //token 不存在  name 意味著 沒有進(jìn)行登錄  返回登錄頁面
    next({ path: "/login" });
  }
  //已經(jīng) 存在TOKEN  name 就可以進(jìn)行
  next();
});

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中的文本空格占位符說明

    vue中的文本空格占位符說明

    這篇文章主要介紹了vue中的文本空格占位符說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • element tree懶加載:load="loadNode"只觸發(fā)一次的解決方案

    element tree懶加載:load="loadNode"只觸發(fā)一次的解決方案

    本文主要介紹了element tree懶加載:load="loadNode"只觸發(fā)一次的解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 關(guān)于net?6+vue?插件axios?后端接收參數(shù)問題

    關(guān)于net?6+vue?插件axios?后端接收參數(shù)問題

    接到這樣一個項目需求是這樣的,前端vue?必須對象傳遞后端也必須對象接收,接下來通過本文給大家介紹下net?6+vue?插件axios?后端接收參數(shù)的問題,需要的朋友可以參考下
    2022-01-01
  • Vue-router優(yōu)化import引入過多導(dǎo)致index文件臃腫問題

    Vue-router優(yōu)化import引入過多導(dǎo)致index文件臃腫問題

    這篇文章主要為大家介紹了Vue-router優(yōu)化import引入過多導(dǎo)致index文件臃腫問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Vue 使用v-model實現(xiàn)控制子組件顯隱效果

    Vue 使用v-model實現(xiàn)控制子組件顯隱效果

    v-model 可以實現(xiàn)雙向綁定的效果,允許父組件控制子組件的顯示/隱藏,同時允許子組件自己控制自身的顯示/隱藏,本文給大介紹Vue 使用v-model實現(xiàn)控制子組件顯隱,感興趣的朋友一起看看吧
    2023-11-11
  • vue接入下載文件接口問題

    vue接入下載文件接口問題

    這篇文章主要介紹了vue接入下載文件接口問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 詳細(xì)解讀VUE父子組件的使用

    詳細(xì)解讀VUE父子組件的使用

    這篇文章主要介紹了詳細(xì)解讀VUE父子組件的使用,今天來講一種子父組件深度耦合的方式,使我們不用額外的創(chuàng)建新的組件,也可以達(dá)到一些效果,下面與你們分享一下
    2023-05-05
  • el-select自定義指令實現(xiàn)觸底加載分頁請求options數(shù)據(jù)(完整代碼和接口可直接用)

    el-select自定義指令實現(xiàn)觸底加載分頁請求options數(shù)據(jù)(完整代碼和接口可直接用)

    某些情況下,下拉框需要做觸底加載,發(fā)請求,獲取option的數(shù)據(jù),下面給大家分享el-select自定義指令實現(xiàn)觸底加載分頁請求options數(shù)據(jù)(附上完整代碼和接口可直接用),感興趣的朋友參考下吧
    2024-02-02
  • webstorm提示?@路徑?Module?is?not?installed的問題

    webstorm提示?@路徑?Module?is?not?installed的問題

    這篇文章主要介紹了webstorm提示?@路徑?Module?is?not?installed的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • vue獲取當(dāng)前日期時間(使用moment和new?Date())

    vue獲取當(dāng)前日期時間(使用moment和new?Date())

    在項目開發(fā)中我遇到了日期范圍選擇器,兩種獲取當(dāng)前日期并做處理的寫法,這里記錄一下,下面這篇文章主要給大家介紹了關(guān)于vue獲取當(dāng)前日期時間(使用moment和new?Date())的相關(guān)資料,需要的朋友可以參考下
    2023-06-06

最新評論