vue中使用router全局守卫实现页面拦截的示例


Posted in Javascript onOctober 23, 2020

一、背景

在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 页面拦截的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
javascript 贪吃蛇实现代码
Nov 22 Javascript
jquery.artwl.thickbox.js  一个非常简单好用的jQuery弹出层插件
Mar 01 Javascript
JavaScript简单实现网页回到顶部功能
Nov 12 Javascript
Js实现双击鼠标自动滚动屏幕的示例代码
Dec 14 Javascript
JavaScript生成二维码图片小结
Dec 27 Javascript
Bootstrap select实现下拉框多选效果
Dec 23 Javascript
js前端实现图片懒加载(lazyload)的两种方式
Apr 24 Javascript
React数据传递之组件内部通信的方法
Dec 31 Javascript
JS实现的邮箱提示补全效果示例
Jan 30 Javascript
echarts鼠标覆盖高亮显示节点及关系名称详解
Mar 17 Javascript
Node.js API详解之 module模块用法实例分析
May 13 Javascript
js实现有趣的倒计时效果
Jan 19 Javascript
vue使用video插件vue-video-player详解
Oct 23 #Javascript
vue-video-player视频播放器使用配置详解
Oct 23 #Javascript
Javascript实现贪吃蛇小游戏(含详细注释)
Oct 23 #Javascript
Vue toFixed保留两位小数的3种方式
Oct 23 #Javascript
vuejs实现下拉框菜单选择
Oct 23 #Javascript
vue 如何使用递归组件
Oct 23 #Javascript
vue 如何从单页应用改造成多页应用
Oct 23 #Javascript
You might like
PHP开发中常用的8个小技巧
2008/08/27 PHP
POSIX 风格和兼容 Perl 风格两种正则表达式主要函数的类比(preg_match, preg_replace, ereg, ereg_replace)
2010/10/12 PHP
php数据结构与算法(PHP描述) 查找与二分法查找
2012/06/21 PHP
自己写了一个php检测文件编码的函数
2014/04/21 PHP
PHP中$GLOBALS['HTTP_RAW_POST_DATA']和$_POST的区别分析
2017/07/03 PHP
基于jquery的滑动样例代码
2010/11/20 Javascript
js字符串的各种格式的转换 ToString,Format
2011/08/08 Javascript
JavaScript获取两个数组交集的方法
2015/06/09 Javascript
浅析函数声明和函数表达式——函数声明的声明提前
2016/05/03 Javascript
浅析Bootstrip的select控件绑定数据的问题
2016/05/10 Javascript
JS跨域交互(jQuery+php)之jsonp使用心得
2016/07/01 Javascript
AngularJS实现给动态生成的元素绑定事件的方法
2016/12/14 Javascript
详解vue-router和vue-cli以及组件之间的传值
2017/07/04 Javascript
解析Angular 2+ 样式绑定方式
2018/01/15 Javascript
Vue实现回到顶部和底部动画效果
2019/07/31 Javascript
Python实现简单的文件传输与MySQL备份的脚本分享
2016/01/03 Python
Python做简单的字符串匹配详解
2017/03/21 Python
基于python中的TCP及UDP(详解)
2017/11/06 Python
对Python中TKinter模块中的Label组件实例详解
2019/06/14 Python
使用Python快乐学数学Github万星神器Manim简介
2019/08/07 Python
Python中flatten( ),matrix.A用法说明
2020/07/05 Python
python开发入门——set的使用
2020/09/03 Python
Python selenium环境搭建实现过程解析
2020/09/08 Python
关于Python不换行输出和不换行输出end=““不显示的问题(亲测已解决)
2020/10/27 Python
CSS3 animation实现逐帧动画效果
2016/06/02 HTML / CSS
瑞士灯具购物网站:Lampenwelt.ch
2018/07/08 全球购物
轻化专业学生实习自我鉴定
2013/09/20 职场文书
成语的广告词
2014/03/19 职场文书
英文演讲稿
2014/05/15 职场文书
广告宣传策划方案
2014/05/21 职场文书
电子专业毕业生自荐信
2014/05/25 职场文书
民族团结演讲稿范文
2014/08/27 职场文书
学校运动会广播稿范文
2014/10/02 职场文书
银行开户授权委托书格式
2014/10/10 职场文书
高考作弊检讨书1500字
2015/02/16 职场文书
三十年再续同学情倡议书
2019/11/27 职场文书