午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

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

一、背景

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

二、使用場(chǎng)景

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

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

三、解決方案

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

頁(yè)面刷新時(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)頁(yè)面)

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

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

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

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

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

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)路由

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

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)頁(yè)面

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

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

五、總結(jié)

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

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

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

3.es6的一些寫法

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

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 91久久久久久久久久久久 | 欧美最猛黑人xxxx黑人猛交 | 粉嫩视频在线观看 | 成年人网站在线观看视频 | 日韩一区二区三区三四区视频在线观看 | 91ts人妖另类精品系列 | 丰满少妇高潮一区二区 | 色婷婷av一区二区三区大白胸 | 久久午夜国产精品 | 日韩欧美高清 | 日本欧美在线观看 | 91激情网| 国产美女永久免费 | a级在线播放 | 久久免费大片 | 日韩欧美中文字幕视频 | 一级片在线观看免费 | 青草视频在线 | 9l视频自拍9l视频自拍 | 国产亚洲区 | 王语嫣跪趴高撅翘臀含白浆 | 久久精品福利视频 | 成年人免费网站视频 | 久久久久国产精品夜夜夜夜夜 | 麻豆av在线播放 | 国产啊v在线观看 | 欧美超碰在线 | 视频国产精品 | 神马久久久久久久久久 | 国产黄色在线看 | 超碰国产在线 | 精品在线一区二区三区 | 亚洲v视频| 国产黄页| 午夜视频免费看 | av网站观看 | 精品国产黄色 | 国产簧片 | 黄色片免费在线播放 | 久久综合视频网 | 日韩中文在线播放 |