日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

reload vue 重新加载_vue面试,谈下router拦截

發布時間:2024/7/23 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 reload vue 重新加载_vue面试,谈下router拦截 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近開始準備面試,盡管是電話面試全身還是充斥著緊張感,一面感覺還不錯,主要是問react和vue的一些生命周期,介紹下redux...,二面印象深刻的是問到了介紹下router攔截,我覺得還是個人對router 的理解不夠,當下有些不知道該怎么回答,然后就沒有回復了,面后去看了下文檔,意識到平時在做的項目在登陸前使用的beforeEach其實就是在做攔截功能,轉換成自己的思想,還是太弱了,把我看到的我能理解的博主的回答寫在這里,做一個記錄。

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

一、背景
  在vue項目中使用vue-router做頁面跳轉時,路由的方式有兩種,一種是靜態路由,另一種是動態路由。而要實現對路由的控制需要使用vuex和router全局守衛進行判斷攔截(安全問題文章最后討論)
二、使用場景
  靜態路由的使用場景:在我們使用靜態路由實現頁面跳轉時,不管我們是否登錄,當我們在地址欄修改地址后,頁面會發生跳轉并展示頁面內容(數據并不會被展示出來),這樣的問題顯然是不能夠被接受的;
  動態路由的使用場景:動態路由無非就是從后端拿到了數據然后在加到router里面了。假如用戶登錄了,在地址欄修改地址便能直接訪問。所以動態路由并不能起到攔截作用。
三、解決方案
  使用vuex+router.beforeEach()+動態路由實現頁面攔截
    頁面刷新時會清楚vuex里面的值;(防止直接修改地址欄)
    router.beforeEach()對跳轉前進行攔截判斷;(對vuex里面的值進行判斷)
    當用戶登錄時請求后臺拿到數據,加載路由.(跳轉頁面)
四、實現過程
  1.首先定義vuex里面的值,需要定義兩個值:a.登錄狀態信息的值 loginInfo b.存儲動態路由的值 routerList


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

//全局守衛 router.beforeEach((to, from, next)=> {let userId = store.state.loginInfo.id;//這里是對登錄后的值進行判斷,也可對token的值進行判斷 //if ( getToken()){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中的默認路由

源代碼

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,} = routerlet 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.登錄成功后存儲成功狀態信息并跳轉頁面


至此,頁面攔截功能已實現。
五、總結
  該方法實現主要用到了:
  1.vuex及頁面刷新時會對vuex進行清空,所以比如退出時要對頁面window.location.reload(),其它地方類似。
  2.router.beforeEach()鉤子函數及關鍵的router.addRoutes方法
  3.es6的一些寫法

總結

以上是生活随笔為你收集整理的reload vue 重新加载_vue面试,谈下router拦截的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。