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之典型高阶函数应用介绍二
Jan 10 Javascript
extjs每个组件要设置唯一的ID否则会出错
Jun 15 Javascript
JavaScript设置表单上传时文件个数的方法
Aug 11 Javascript
JavaScript中判断数据类型的方法总结
May 24 Javascript
JavaScript中的Number数字类型学习笔记
May 26 Javascript
Node.js readline 逐行读取、写入文件内容的示例
Mar 01 Javascript
vue.js项目nginx部署教程
Apr 05 Javascript
vue.js父子组件通信动态绑定的实例
Sep 28 Javascript
基于vue-upload-component封装一个图片上传组件的示例
Oct 16 Javascript
在微信小程序中使用vant的方法
Jun 07 Javascript
node创建Vue项目步骤详解
Mar 06 Javascript
JavaScript中ES6规范中let和const的用法和区别
Aug 06 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框架的性能
2008/01/10 PHP
Laravel 中获取上一篇和下一篇数据
2015/07/27 PHP
PHP几个实用自定义函数小结
2016/01/25 PHP
js不是基础的基础
2006/12/24 Javascript
关于JavaScript定义类和对象的几种方式
2010/11/09 Javascript
JavaScript表单通过正则表达式验证电话号码
2014/03/14 Javascript
js调用浏览器打印模块实现点击按钮触发自定义函数
2014/03/21 Javascript
jQuery使用append在html元素后同时添加多项内容的方法
2015/03/26 Javascript
JavaScript实现表格快速变色效果代码
2015/08/19 Javascript
JavaScript位移运算符(无符号) >>> 三个大于号 的使用方法详解
2016/03/31 Javascript
canvas雪花效果核心代码分享
2017/02/19 Javascript
JavaScript实现body内任意节点的自定义属性功能示例
2017/09/18 Javascript
浅谈webpack编译vue项目生成的代码探索
2017/12/11 Javascript
angular6根据environments配置文件更改开发所需要的环境的方法
2019/03/06 Javascript
vue项目中使用bpmn-自定义platter的示例代码
2020/05/11 Javascript
原生js实现表格循环滚动
2020/11/24 Javascript
用python写asp详细讲解
2013/12/16 Python
Python中运行并行任务技巧
2015/02/26 Python
python字符串常用方法
2018/06/14 Python
Django框架设置cookies与获取cookies操作详解
2019/05/27 Python
Pytorch 多块GPU的使用详解
2019/12/31 Python
Python实现图片查找轮廓、多边形拟合、最小外接矩形代码
2020/07/14 Python
Python pip install之SSL异常处理操作
2020/09/03 Python
美国运动鞋和服装网上商店:YCMC
2018/09/15 全球购物
英国儿童鞋和靴子:Start-Rite
2019/05/06 全球购物
交通安全演讲稿
2014/01/07 职场文书
会计的岗位职责
2014/03/15 职场文书
旅行社各个岗位职责
2014/03/15 职场文书
《花木兰》教学反思
2014/04/09 职场文书
会计学自荐信
2014/06/03 职场文书
党员演讲稿
2014/09/04 职场文书
事业单位人员的自我评价范文
2014/09/21 职场文书
医生学习党的群众路线教育实践活动心得体会
2014/11/03 职场文书
妈妈别哭观后感
2015/06/08 职场文书
重阳节座谈会主持词
2015/07/03 职场文书
Python超详细分步解析随机漫步
2022/03/17 Python