亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中使用router全局守衛(wèi)實(shí)現(xiàn)頁面攔截的示例

 更新時(shí)間:2020年10月23日 15:23:58   作者:蟈民黨  
這篇文章主要介紹了vue中使用router全局守衛(wèi)實(shí)現(xiàn)頁面攔截的示例,幫助大家維護(hù)自己的項(xiàng)目,感興趣的朋友可以了解下

一、背景

  在vue項(xiàng)目中使用vue-router做頁面跳轉(zhuǎn)時(shí),路由的方式有兩種,一種是靜態(tài)路由,另一種是動(dòng)態(tài)路由。而要實(shí)現(xiàn)對(duì)路由的控制需要使用vuex和router全局守衛(wèi)進(jìn)行判斷攔截(安全問題文章最后討論)

二、使用場景

  靜態(tài)路由的使用場景:在我們使用靜態(tài)路由實(shí)現(xiàn)頁面跳轉(zhuǎn)時(shí),不管我們是否登錄,當(dāng)我們?cè)诘刂窓谛薷牡刂泛?,頁面?huì)發(fā)生跳轉(zhuǎn)并展示頁面內(nèi)容(數(shù)據(jù)并不會(huì)被展示出來),這樣的問題顯然是不能夠被接受的;

  動(dòng)態(tài)路由的使用場景:動(dòng)態(tài)路由無非就是從后端拿到了數(shù)據(jù)然后在加到router里面了。假如用戶登錄了,在地址欄修改地址便能直接訪問。所以動(dòng)態(tài)路由并不能起到攔截作用。

三、解決方案

  使用vuex+router.beforeEach()+動(dòng)態(tài)路由實(shí)現(xiàn)頁面攔截

    頁面刷新時(shí)會(huì)清楚vuex里面的值;(防止直接修改地址欄)

    router.beforeEach()對(duì)跳轉(zhuǎn)前進(jìn)行攔截判斷;(對(duì)vuex里面的值進(jìn)行判斷)

    當(dāng)用戶登錄時(shí)請(qǐng)求后臺(tái)拿到數(shù)據(jù),加載路由.(跳轉(zhuǎn)頁面)

四、實(shí)現(xiàn)過程

1.首先定義vuex里面的值,需要定義兩個(gè)值:

a.登錄狀態(tài)信息的值 loginInfo 

b.存儲(chǔ)動(dòng)態(tài)路由的值 routerList

2.router.beforeEach()對(duì)路由跳轉(zhuǎn)前進(jìn)行控制 

//全局守衛(wèi)
router.beforeEach((to, from, next)=> {
 let userId = store.state.loginInfo.id;
 //這里是對(duì)登錄后的值進(jìn)行判斷,也可對(duì)token的值進(jìn)行判斷
 if (userId === '') {
  if (to.meta.requireAuth || to.name == null) {
  next({path: '/'})
  } else {
  next();
  }
 } else {
  //初始化動(dòng)態(tài)路由方法
  initRouter(router, store); 
  next();
 }
 }
);

3.初始化動(dòng)態(tài)路由

在全局守衛(wèi)對(duì)應(yīng)條件下加載動(dòng)態(tài)路由數(shù)據(jù)routerList和在登錄成功時(shí)存儲(chǔ)登錄成功的信息loginInfo 

新建一個(gè)xxx.js文件 引入axios 創(chuàng)建一個(gè)函數(shù)并使用export 暴露該方法;

請(qǐng)求成功拿到數(shù)據(jù)后,把數(shù)據(jù)造成和routes里的數(shù)據(jù)一樣。然后使用 router.addRoutes 添加進(jìn)去;

index中的默認(rèn)路由

import axios from 'axios'
export const initRouter = (router,store)=>{
 if (store.state.routerList.length > 0) {
 return;
 }
 axios.get(' URL')
  .then((rest)=>{
  let routerList = [];
  if(rest.data.success){
  let routers = rest.data.body;
  routers.forEach(router=>{
   let {
    path,
    component,
    name,
   } = router
   let routerObj = {
    path:path,
    name:name,
    component(resolve){
    if (component.startsWith("index")) {
     require(['../components/' + component + '.vue'], resolve)
    }  
    
    },
    meta:{requireAuth:true} //是否是登錄權(quán)限控制
   };
   routerList.push(routerObj);
   });
  //add到router中
  router.addRoutes(routerList); 
  //存儲(chǔ)到vuex中
  store.commit('routerList', routerList); 

  }else{
   console.log(rest.data.error);
  }
 }).catch((error)=>{
  console.log(error);
 })
}

4.登錄成功后存儲(chǔ)成功狀態(tài)信息并跳轉(zhuǎn)頁面

 至此,頁面攔截功能已實(shí)現(xiàn)。

五、總結(jié)

  該方法實(shí)現(xiàn)主要用到了:

  1.vuex及頁面刷新時(shí)會(huì)對(duì)vuex進(jìn)行清空,所以比如退出時(shí)要對(duì)頁面window.location.reload(),其它地方類似。

  2.router.beforeEach()鉤子函數(shù)及關(guān)鍵的router.addRoutes方法

  3.es6的一些寫法

以上就是vue中使用router全局守衛(wèi)實(shí)現(xiàn)頁面攔截的示例的詳細(xì)內(nèi)容,更多關(guān)于vue 頁面攔截的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue+Canvas制作簡易的水印添加器小工具

    Vue+Canvas制作簡易的水印添加器小工具

    隨著搬運(yùn)工的逐漸增加,原創(chuàng)作者的利益收到了極大的影響。所以給圖片或視頻加上水印顯得極其重要。本文分享一個(gè)由canvas和vue.js制作的圖片水印添加器,需要的可參考一下
    2022-06-06
  • 淺析Vue中method與computed的區(qū)別

    淺析Vue中method與computed的區(qū)別

    在new Vue的配置參數(shù)中的computed和methods都可以處理大量的邏輯代碼,但是什么時(shí)候用哪個(gè)屬性,要好好區(qū)分一下才能做到正確的運(yùn)用vue。這篇文章主要介紹了Vue中method與computed的區(qū)別,需要的朋友可以參考下
    2018-03-03
  • Vue 兄弟組件通信的方法(不使用Vuex)

    Vue 兄弟組件通信的方法(不使用Vuex)

    本篇文章主要介紹了Vue 兄弟組件通信的方法(不使用Vuex),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • uni-app中使用ECharts配置四種不同的圖表(示例詳解)

    uni-app中使用ECharts配置四種不同的圖表(示例詳解)

    在uni-app中集成ECharts可以為我們的應(yīng)用提供強(qiáng)大的圖表功能,我們?cè)敿?xì)說一下如何在uni-app中使用ECharts,并配置四種不同的圖表,感興趣的朋友跟隨小編一起看看吧
    2024-01-01
  • Vue的樣式綁定詳解

    Vue的樣式綁定詳解

    這篇文章主要為大家詳細(xì)介紹了Vue的樣式綁定,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue3中如何獲取proxy包裹的數(shù)據(jù)

    vue3中如何獲取proxy包裹的數(shù)據(jù)

    這篇文章主要介紹了vue3中如何獲取proxy包裹的數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 解決vux 中popup 組件Mask 遮罩在最上層的問題

    解決vux 中popup 組件Mask 遮罩在最上層的問題

    這篇文章主要介紹了解決vux 中popup 組件Mask 遮罩在最上層的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 淺談Vue?DIFF

    淺談Vue?DIFF

    本文主要介紹了淺談Vue?DIFF,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue中的router-view父子組件傳參方式

    vue中的router-view父子組件傳參方式

    這篇文章主要介紹了vue中的router-view父子組件傳參方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 解決vue過濾器filters獲取不到this對(duì)象的問題

    解決vue過濾器filters獲取不到this對(duì)象的問題

    這篇文章主要介紹了解決vue過濾器filters獲取不到this對(duì)象的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01

最新評(píng)論