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

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

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

前言

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

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

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

編程式路由導(dǎo)航作用就是不借助<router-link>實(shí)現(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()方法,可以在瀏覽歷史中前進(jìn)和后退。

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

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

2)$router.forward() 在歷史記錄中,前進(jìn)到下一個(gè)頁(yè)面。

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

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

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

全局守衛(wèi)

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

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

to:是將要訪問(wèn)的路由的信息對(duì)象

from:是將要離開的路由的信息對(duì)象

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

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

控制后臺(tái)主頁(yè)的訪問(wèn)權(quán)限

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

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

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

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

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

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

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

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

組件路由守衛(wèi)

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

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

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

    如何使用Vue做個(gè)簡(jiǎn)單的比較兩個(gè)數(shù)字大小頁(yè)面

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

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

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

    vue+iview實(shí)現(xiàn)手機(jī)號(hào)分段輸入框

    這篇文章主要為大家詳細(xì)介紹了vue+iview實(shí)現(xiàn)手機(jī)號(hào)分段輸入框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    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,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Vue項(xiàng)目通過(guò)vue-i18n實(shí)現(xiàn)國(guó)際化方案(推薦)

    Vue項(xiàng)目通過(guò)vue-i18n實(shí)現(xiàn)國(guó)際化方案(推薦)

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

最新評(píng)論