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

ea8e057e04a73785ee2e8606408642dc.png


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中的默认路由

a378c4326aea26ffa2ecd065ffbe28e6.png

源代码

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.登录成功后存储成功状态信息并跳转页面

def94bb6aaab451aef7ebdd8fd30be60.png


至此,页面拦截功能已实现。
五、总结
  该方法实现主要用到了:
  1.vuex及页面刷新时会对vuex进行清空,所以比如退出时要对页面window.location.reload(),其它地方类似。
  2.router.beforeEach()钩子函数及关键的router.addRoutes方法
  3.es6的一些写法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/489923.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文小刚:创新就是孩子的游戏

来源: 返朴 撰文 | 文小刚 (麻省理工学院终身教授、格林讲席教授)1什么是创新应用科学(工程技术)的目的是利用已知的知识,创造社会价值,造福人类。而基础科学的目的是创造新知识,开拓…

bzoj1532: [POI2005]Kos-Dicing

1532: [POI2005]Kos-Dicing Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1520 Solved: 516[Submit][Status][Discuss]Description Dicing 是一个两人玩的游戏,这个游戏在Byteotia非常流行. 甚至人们专门成立了这个游戏的一个俱乐部. 俱乐部的人时常在一起玩这个游戏然后评…

python搭配什么数据库_python 连接操作数据库(一)

一、下面我们所说的就是连接mysql的应用: 1、其实在python中连接操作mysql的模块有多个,在这里我只给大家演示pymysql这一个模块(其实我是感觉它比较好用而已): pymysql是第三方的一个模块,需要我们自己安装…

【用word快速输入公式】希腊字母名称和大小写

用word按住alt和加号,先输入\ 然后后面跟代码,输完以后用空格转换。 输入大写就首字母大写,小写就首字母小写。代码基本就是发音。 大写小写发音AαAlphaBβBetaΓγGammaΔδDeltaΕεEpsilonΖζZetaΝνNuΞξXiOοOmicronΠπPiPρRhoΣ…

xadsafe做暗刷_深蓝维护通道有暗刷? - 综合技术讨论大区 - 死性不改BBS - 网维行业自由、中立的技术与信息交流平台 - Powered by Discuz!...

本帖最后由 小米 于 2018-4-27 04:52 编辑今天发现的&#xff0c;只要一打开QQ&#xff0c;C盘根目录生成NTDETECT.HTA文件&#xff0c;内容是>tpircs/<esolc.wodniw)Li(nuR.llehS005 peels.tpircsw2,Li eliFoTevaS.teGa)ydoBesnopser.tsoP(etirW.teGa)(nepO.teGa1epyT.t…

GE数字化重塑的启示:调整阵型,再战工业互联网!

来源&#xff1a;中国华能&#xff08;部分内容参考《财经》杂志韩舒淋“从GE数字化业务大调整看工业互联网未来”&#xff09;打响“工业互联网”第一枪的GE&#xff08;美国通用电气&#xff09;&#xff0c;曾是全球市值最高的工业巨头&#xff0c;如今市值却缩水至巅峰时期…

python简单图画程序_用Python的Turtple画图形

不知道各位是否还记得在小学或者初中的时候&#xff0c;我们接触过一种语言叫做logo语言&#xff0c;这个语言可以画正方形&#xff0c;画三角形&#xff0c;画圆。而用Python画图形也有点类似logo语言的意思。 在画图之前&#xff0c;我们需要启动一个模块&#xff0c;turtple…

Matlab自带的Bessel函数及如何扩展其应用

第一类虚宗量Bessel函数I_v: help besseli第二类虚宗量Bessel函数K_v: help besselk第一类Bessel函数J_v help besselj第二类Bessel函数 Y_v(诺伊曼函数N_v) help bessely汉克尔函数H_v help besselh以上函数的问题是输出结果都是实数。如果想算复数域&#xff0c;以上函数…

freeRTOS实时操作系统学习笔记

温馨提示&#xff1a;点击图片查看大图更清晰 —————————————————————————————↑↑↑上方资源下载后可获取xmind原文件。 1、freeRTOS移植和配置脑图 2、内核源码学习

mysql删除记录后id不连续_Mysql数据库中使用DELETE语句时,一般删除一条记录后ID会不连续,才能让序号继续按顺序排列?...

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":7,"count":7}]},"card":[{"des":"提供基于开源Elasticsearch及商业版X-Pack插…

通用AI——未来真正强健的人工智能?

来源&#xff1a;王宏琳科学网博客一本新书纽约大学马库斯&#xff08;Gary Marcus&#xff09;教授和戴维斯&#xff08;Ernest Davis&#xff09;教授2019年新书&#xff08;参考资料[1]&#xff09;的书名&#xff0c;颇吸引眼球&#xff1a;《Rebooting AI : 构建我们可以信…

signed 与 unsigned 有符号和无符号数

unsigned int a 0; unsigned int b -1; // b 为 0xffffffff unsigned int c a - 1; // c 为 0xffffffff 转载于:https://www.cnblogs.com/mtcnn/p/9423663.html

使用matlab播放特定频率的声音

A2;%振幅 f_0397%声音频率 fs10000; %采样频率 N3000; % 信号样点数&#xff0c;播放时长 yA*sin(2*pi*f_0*(0:N-1)/fs); %单频信号 sound(y,fs); %通过声卡放音 另外matlab还自带好多声音&#xff0c;需要的时候搜一搜就好了。

python开发工具管理系统_Python开发桌面软件文档及网址管理工具,强迫症的福音...

原标题&#xff1a;Python开发桌面软件文档及网址管理工具&#xff0c;强迫症的福音写在前面 这两天用python鼓捣开发了一个软件&#xff0c;分享给同事&#xff0c;觉得很实用&#xff0c;可以大大提高工作效率&#xff0c;想通过平台分享出来给大家 希望给爱好python的童鞋做…

halcon 将数据保存到excel_pandas筛选、合并、批量保存excel数据

人生苦短&#xff0c;我学python&#xff01;python是目前最流行的编程语言&#xff0c;功能十分强大&#xff0c;在爬虫、数据分析、人工智能方面均得以广泛应用。本专辑主要分享两个数据分析库numpy和pandas在数据分析方面的基础知识和各种技能&#xff0c;pandas的快、准、简…

边缘计算参考架构3.0

来源&#xff1a;萤火虫智能家居沙龙全球已经掀起行业数字化转型的浪潮&#xff0c;数字化是基 础&#xff0c;网络化是支撑&#xff0c;智能化是目标。通过对人、物、环境、过程等对象&#xff0c;进行数字化而产生数据&#xff0c;通过网络化实 现数据的价值流动&#xff0c;…

以二维振动为例展示使用matlab画圆形三维图的偷懒方法

画图主要是用极坐标&#xff0c;我们使用画复数的函数来画。 clc;%清空上次的 %draw_Bessel%画这个东西 a4;%圆形半径% %定义角向和径向的步长和范围 fai[-4:0.1:4]; r[0:0.02:a];%将fai和r组合起来并生成复平面 [R,T] meshgrid(fai,r); Z R.*exp(1i*T);%和画具体图有关的 m…

tensorflow 转张量类型为float_5个简单的步骤掌握Tensorflow的Tensor

在这篇文章中&#xff0c;我们将深入研究Tensorflow Tensor的细节。我们将在以下五个简单步骤中介绍与Tensorflow的Tensor中相关的所有主题&#xff1a;第一步&#xff1a;张量的定义→什么是张量&#xff1f;第二步&#xff1a;创建张量→创建张量对象的函数第三步&#xff1a…

指针和字符串

指针和字符串 [前言] 我们所写的应用程序都需要从网络获取数据&#xff0c;或者从网络下载数据&#xff0c;这些操作都需要和网络另一端的服务器进行数据传输&#xff0c;这些数据都是通过文件进行传输的&#xff0c;文件中就是字符串&#xff0c;我们程序员需要保证正确解析从…

华为手机怎么使用读卡器_华为手机使用小窍门

华为手机电池耐用&#xff0c;信号好&#xff0c;系统流畅&#xff0c;外观也一改以往的呆板现在追求时尚&#xff0c;所以深得国人的喜爱&#xff0c;也因为美国的打压激起了国人的爱国意识&#xff0c;华为在国内手机销量高居第一&#xff0c;使用的人很多。现在国产最好的手…