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

vue-router的導(dǎo)航守衛(wèi)使用最新講解

 更新時間:2022年12月16日 16:36:03   作者:亦世凡華、  
這篇文章主要介紹了vue-router的導(dǎo)航守衛(wèi)使用講解,vue-router提供了許多編程式導(dǎo)航的API,其中最常見的導(dǎo)航API有很多種,本文給大家詳細講解,需要的朋友可以參考下

前言

在瀏覽器中點擊鏈接實現(xiàn)導(dǎo)航的方式,叫做聲明式導(dǎo)航。例如:普通網(wǎng)頁中點擊<a>鏈接、vue項目中點擊<router-link>都屬于聲明式導(dǎo)航。

在瀏覽器中調(diào)用API方法實現(xiàn)的導(dǎo)航方式,叫做編程式導(dǎo)航。例如:普通網(wǎng)頁中調(diào)用loaction.href跳轉(zhuǎn)到新頁面的方式,屬于編程式導(dǎo)航。

vue-router中編程式導(dǎo)航API

編程式路由導(dǎo)航作用就是不借助<router-link>實現(xiàn)路由跳轉(zhuǎn),讓路由跳轉(zhuǎn)更加靈活。

vue-router提供了許多編程式導(dǎo)航的API,其中最常見的導(dǎo)航API有以下幾種:

1)this.$router.push('hash地址')

跳轉(zhuǎn)到指定的 hash 地址,并增加一條歷史記錄

2)this.$router.replace('hash地址')

跳轉(zhuǎn)到指定的 hash 地址,并替換掉當(dāng)前的歷史記錄。

3)this.$router.go(數(shù)值n)

調(diào)用this.$router.go()方法,可以在瀏覽歷史中前進和后退。

在實際開發(fā)中,一般只會前進和后退一層頁面。因此 vue-router 提供了如下兩個便捷方法:

1)$router.back() 在歷史記錄中,后退到上一個頁面。

2)$router.forward() 在歷史記錄中,前進到下一個頁面。

這兩個方法一般可以放在行內(nèi)樣式里面使用,更便捷一點,注意:行內(nèi)樣式里面就不必再寫this了

導(dǎo)航守衛(wèi)

導(dǎo)航守衛(wèi)也叫路由守衛(wèi),可以控制路由的訪問權(quán)限,示意圖如下:

全局守衛(wèi)

全局前置守衛(wèi):每次發(fā)生路由的導(dǎo)航跳轉(zhuǎn)時,都會觸發(fā)全局前置守衛(wèi)。因此,在全局前置守衛(wèi)中,程序員可以對每個路由進行訪問權(quán)限的控制,那么如何創(chuàng)建全局前置守衛(wèi)呢?如下:

全局前置守衛(wèi)的回調(diào)函數(shù)中接收3個形參,如上圖所示,其作用為:

to:是將要訪問的路由的信息對象

from:是將要離開的路由的信息對象

next:是一個函數(shù),調(diào)用 next() 表示放行,允許這次路由導(dǎo)航

next函數(shù)的3種調(diào)用方式:如下圖所示

控制后臺主頁的訪問權(quán)限

router.beforeEach(function (to, from, next) {
  if (to.path === '/main') {
    // 要訪問后臺主頁,需要判斷是否有token
    const token = localStorage.getItem('token')
    if (token) { // token值存在
      next()
    } else {
      // 沒有登錄,強制跳轉(zhuǎn)到登錄頁
      next('/login')
    }
  } else {
    next() // 訪問的不是后臺主頁,直接放行
  }
})

當(dāng)然我們也可以通過全局前置守衛(wèi)來進行權(quán)限的查看,案例如下:

// 全局前置守衛(wèi):初始化時、每次路由切換前執(zhí)行
router.beforeEach((to, from, next) => {
  console.log('beforeEach', to, from)
  if (to.meta.isAuth) { // 判斷當(dāng)前路由是否需要進行權(quán)限控制
    if (localStorage.getItem('token') === 'key') { // 權(quán)限控制的具體規(guī)則
      next() // 放行
    } else {
      alert('暫無權(quán)限查看')
    }
  } else {
    next() // 放行
  }
})

全局后置守衛(wèi): 全局后置守衛(wèi)相對于前置守衛(wèi)使用的次數(shù)相對較少,后置守衛(wèi)一般使用在項目的title實時發(fā)送變化時來使用。

// 全局后置守衛(wèi),初始化時執(zhí)行、每次路由切換后執(zhí)行
router.afterEach((to, from) => {
  console.log('afterEach', to, from)
  if (to.meta.title) {
    document.title = to.meta.title // 修改網(wǎng)頁的title
  } else {
    document.title = 'process'
  }
})

獨享路由守衛(wèi)

顧名思義獨享路由守衛(wèi)就是某一個路由獨享的,和其他路由沒關(guān)系。如下:

beforeEnter (to, from, next) {
  console.log('beforeEach', to, from)
  if (to.meta.isAuth) { // 判斷當(dāng)前路由是否需要進行權(quán)限控制
    if (localStorage.getItem('admin') === 'admin123') { // 權(quán)限控制的具體規(guī)則
      next() // 放行
    } else {
      alert('暫無權(quán)限查看')
    }
  } else {
    next() // 放行
  }
}

組件路由守衛(wèi)

顧名思義是在組件內(nèi)部使用的守衛(wèi)。如下:使用方式和上文一樣,這里不在贅述。

// 通過路由規(guī)則,進入該組件時被調(diào)用
beforeRouteEnter (to, from, next) { },
// 通過路由規(guī)則,離開該組件時被調(diào)用
beforeRouteLeave (to, from, next) { }

當(dāng)然,作者講解的也不是太全面,如果你想更細致的了解vue-router的導(dǎo)航守衛(wèi),推薦看一下官方文檔對導(dǎo)航守衛(wèi)的說明:導(dǎo)航守衛(wèi)官方說明 。

到此這篇關(guān)于vue-router的導(dǎo)航守衛(wèi)使用講解的文章就介紹到這了,更多相關(guān)vue-router的導(dǎo)航守衛(wèi)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中傳參params和data的區(qū)別

    vue中傳參params和data的區(qū)別

    本文主要介紹了vue中傳參params和data的區(qū)別,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue3?使用v-model實現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)

    Vue3?使用v-model實現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)

    這篇文章主要介紹了Vue3?使用v-model實現(xiàn)父子組件通信(常用在組件封裝規(guī)范中)的方法,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • 詳解vite2.0配置學(xué)習(xí)(typescript版本)

    詳解vite2.0配置學(xué)習(xí)(typescript版本)

    這篇文章主要介紹了詳解vite2.0配置學(xué)習(xí)(typescript版本),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • 了解VUE的render函數(shù)的使用

    了解VUE的render函數(shù)的使用

    本篇文章主要介紹了了解VUE的render函數(shù)的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 優(yōu)化Vue頁面中的表單布局和樣式的技巧

    優(yōu)化Vue頁面中的表單布局和樣式的技巧

    在日常開發(fā)中,Vue 項目中的表單布局和樣式優(yōu)化是一個重要的環(huán)節(jié),通過合理的布局與美觀的樣式設(shè)計,不僅可以提升用戶體驗,還能增加頁面的實用性和觀賞性,本文將總結(jié)幾個常見的表單和表格布局優(yōu)化的技巧,需要的朋友可以參考下
    2024-10-10
  • 如何使用Vue做個簡單的比較兩個數(shù)字大小頁面

    如何使用Vue做個簡單的比較兩個數(shù)字大小頁面

    這篇文章主要給大家介紹了關(guān)于如何使用Vue做個簡單的比較兩個數(shù)字大小頁面的相關(guān)資料,實現(xiàn)一個比較兩個數(shù)字大小的頁面,練習(xí)Vue實例的創(chuàng)建、數(shù)據(jù)綁定和事件監(jiān)聽方法,需要的朋友可以參考下
    2023-10-10
  • VUE項目調(diào)用高德地圖的詳細步驟

    VUE項目調(diào)用高德地圖的詳細步驟

    要在Web頁面中加入地圖,我推薦你使用高德地圖JSAPI,下面這篇文章主要給大家介紹了關(guān)于VUE項目調(diào)用高德地圖的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • vue+iview實現(xiàn)手機號分段輸入框

    vue+iview實現(xiàn)手機號分段輸入框

    這篇文章主要為大家詳細介紹了vue+iview實現(xiàn)手機號分段輸入框,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • element UI 2.15.13與vue2.0表格勾選回顯關(guān)鍵demo

    element UI 2.15.13與vue2.0表格勾選回顯關(guān)鍵demo

    這篇文章主要為大家介紹了element UI 2.15.13與vue2.0表格勾選回顯關(guān)鍵demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Vue項目通過vue-i18n實現(xiàn)國際化方案(推薦)

    Vue項目通過vue-i18n實現(xiàn)國際化方案(推薦)

    這篇文章主要介紹了Vue項目通過vue-i18n實現(xiàn)國際化方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12

最新評論