国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:70日期:2022-11-13 13:20:08

一、背景

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

二、使用場景

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

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

三、解決方案

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

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

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

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

四、實現過程

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

a.登錄狀態信息的值 loginInfo

b.存儲動態路由的值 routerList

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

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

//全局守衛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全局守衛實現頁面攔截的示例

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 頁面攔截的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 欧美日韩精品一区二区三区视频在线 | 一区视频在线 | 成年男女免费视频 | 亚洲 欧美 国产 日韩 制服 bt | 国产人成亚洲第一网站在线播放 | 日本三级香港三级人妇 m | 国产小视频在线高清播放 | 99精品视频在线观看 | 亚洲小视频在线观看 | 久久国产一片免费观看 | 一级毛片免费观看久 | 在线精品视频免费观看 | 国产99在线播放 | 国产精品国三级国产aⅴ | 美女张腿男人桶免费视频 | 欧美jizzhd精品欧美高清 | 在线免费视频 | 中文字幕免费在线视频 | 欧美大片无尺码在线观看 | 996re免费热在线视频手机 | 被老外玩爽的中国美女视频 | 免费又黄又爽视频 | 久久精品国产一区二区三区日韩 | 自拍视频在线观看视频精品 | 真实国产普通话对白乱子子伦视频 | 国产日本韩国不卡在线视频 | 九九视频在线观看视频6偷拍 | 色老头老太做爰视频在线观看 | 玖玖在线免费视频 | 久久久久久91精品色婷婷 | 中国人免费观看高清在线观看二区 | 美女午夜色视频在线观看 | 亚洲欧美片 | 成年男女的免费视频网站 | 国产精品久久久久毛片真精品 | 久久青草视频 | 亚洲制服欧美自拍另类 | 欧美成人久久久 | 国产午夜亚洲精品 | 婷婷在线成人免费观看搜索 | 2020亚洲男人天堂 |