一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue中使用router全局守衛實現頁面攔截的示例

vue中使用router全局守衛實現頁面攔截的示例

2021-11-04 15:16蟈民黨 JavaScript

這篇文章主要介紹了vue中使用router全局守衛實現頁面攔截的示例,幫助大家維護自己的項目,感興趣的朋友可以了解下

一、背景

  在vue項目中使用vue-router做頁面跳轉時,路由的方式有兩種,一種是靜態路由,另一種是動態路由。而要實現對路由的控制需要使用vuex和router全局守衛進行判斷攔截(安全問題文章最后討論)

二、使用場景

  靜態路由的使用場景:在我們使用靜態路由實現頁面跳轉時,不管我們是否登錄,當我們在地址欄修改地址后,頁面會發生跳轉并展示頁面內容(數據并不會被展示出來),這樣的問題顯然是不能夠被接受的;

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

三、解決方案

  使用vuex+router.beforeEach()+動態路由實現頁面攔截

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

    router.beforeEach()對跳轉前進行攔截判斷;(對vuex里面的值進行判斷)

    當用戶登錄時請求后臺拿到數據,加載路由.(跳轉頁面)

四、實現過程

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

a.登錄狀態信息的值 loginInfo 

b.存儲動態路由的值 routerList

vue中使用router全局守衛實現頁面攔截的示例

2.router.beforeEach()對路由跳轉前進行控制 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//全局守衛
router.beforeEach((to, from, next)=> {
 let userId = store.state.loginInfo.id;
 //這里是對登錄后的值進行判斷,也可對token的值進行判斷
 if (userId === '') {
  if (to.meta.requireAuth || to.name == null) {
  next({path: '/'})
  } else {
  next();
  }
 } else {
  //初始化動態路由方法
  initRouter(router, store);
  next();
 }
 }
);

3.初始化動態路由

在全局守衛對應條件下加載動態路由數據routerList和在登錄成功時存儲登錄成功的信息loginInfo 

新建一個xxx.js文件 引入axios 創建一個函數并使用export 暴露該方法;

請求成功拿到數據后,把數據造成和routes里的數據一樣。然后使用 router.addRoutes 添加進去;

index中的默認路由

vue中使用router全局守衛實現頁面攔截的示例

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
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} //是否是登錄權限控制
   };
   routerList.push(routerObj);
   });
  //add到router中
  router.addRoutes(routerList);
  //存儲到vuex中
  store.commit('routerList', routerList);
 
  }else{
   console.log(rest.data.error);
  }
 }).catch((error)=>{
  console.log(error);
 })
}

4.登錄成功后存儲成功狀態信息并跳轉頁面

vue中使用router全局守衛實現頁面攔截的示例

 至此,頁面攔截功能已實現。

五、總結

  該方法實現主要用到了:

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

  2.router.beforeEach()鉤子函數及關鍵的router.addRoutes方法

  3.es6的一些寫法

以上就是vue中使用router全局守衛實現頁面攔截的示例的詳細內容,更多關于vue 頁面攔截的資料請關注服務器之家其它相關文章!

原文鏈接:https://www.cnblogs.com/xufeikko/p/10169826.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 女人扒开下面让男人桶爽视频 | 91在线播 | aⅴ免费视频| 国内精品久久久久久久久 | 色多多影院 | 成年人在线观看视频免费 | 幻女free性zozo交体内谢 | 亚偷熟乱区视频在线观看 | 免费看片aⅴ免费大片 | 欧美人禽杂交av片 | x8x8在线观看免费 | 精品久久免费视频 | 超91精品手机国产在线 | 国产区一二三四区2021 | 娇妻终于接受了3p的调教 | 国产综合成色在线视频 | 91制片厂 果冻传媒 天美传媒 | 搡60一70岁的老女人小说 | 亚洲婷婷在线视频 | xnxx动漫| 护士的小嫩嫩好紧好舒服 | 手机在线观看国产精选免费 | 色橹| sese在线播放 | 国产精品久久久久久五月尺 | 日韩不卡一区二区三区 | 成人二区 | 韩国帅男同gay网站 韩国三级在线播放 | 成年男女免费视频观看性 | 97久久精品午夜一区二区 | 91麻豆精品国产片在线观看 | 校园刺激全黄H全肉细节文 校草让我脱了内裤给全班看 | 无人区免费一二三四乱码 | 日本高清色视频www 日本高清免费观看 | a看片| 毛片手机在线视频免费观看 | 黑人与欧洲女子性大战 | 欧洲第一页 | 国产99精品视频 | 成人免费观看www视频 | 国产综合亚洲欧美日韩一区二区 |