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 相关文章推荐
利用Dojo和JSON建立无限级AJAX动态加载的功能模块树
Mar 24 Javascript
捕获关闭窗口的脚本
Jan 10 Javascript
jquery实现图片渐变切换兼容ie6/Chrome/Firefox
Aug 02 Javascript
jQuery获取节点和子节点文本的方法
Jul 22 Javascript
javascript根据时间生成m位随机数最大13位
Oct 30 Javascript
node.js中的fs.rmdir方法使用说明
Dec 16 Javascript
jQuery mobile的header和footer在点击屏幕的时候消失的解决办法
Jul 01 Javascript
javascript html5轻松实现拖动功能
Mar 01 Javascript
Node.js中的require.resolve方法使用简介
Apr 23 Javascript
Express本地测试HTTPS的示例代码
Jun 06 Javascript
Vue文本模糊匹配功能如何实现
Jul 30 Javascript
vue实现验证用户名是否可用
Jan 20 Vue.js
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获取中英混合字符串长度的方法
2014/06/07 PHP
kohana框架上传文件验证规则写法示例
2014/07/14 PHP
PHP使用flock实现文件加锁的方法
2015/07/01 PHP
详解PHP中instanceof关键字及instanceof关键字有什么作用
2015/11/05 PHP
PHP自定义函数获取汉字首字母的方法
2016/12/01 PHP
用 Javascript 验证表单(form)中多选框(checkbox)值
2009/09/08 Javascript
JS Range HTML文档/文字内容选中、库及应用介绍
2011/05/12 Javascript
JS基于cookie实现来宾统计记录访客信息的方法
2015/08/04 Javascript
JS日期对象简单操作(获取当前年份、星期、时间)
2016/10/26 Javascript
Vue.js学习笔记之修饰符详解
2017/07/25 Javascript
微信小程序实现页面跳转传值以及获取值的方法分析
2017/12/18 Javascript
微信小程序支付PHP代码
2018/08/23 Javascript
Bootstrap 按钮样式与使用代码详解
2018/12/09 Javascript
微信小程序日历组件使用方法详解
2018/12/29 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
2019/11/06 Javascript
vue学习笔记之Vue中css动画原理简单示例
2020/02/29 Javascript
解决vue单页面应用打包后相对路径、绝对路径相关问题
2020/08/14 Javascript
vue实现折线图 可按时间查询
2020/08/21 Javascript
解决vue scoped html样式无效的问题
2020/10/24 Javascript
从源码角度来回答keep-alive组件的缓存原理
2021/01/18 Javascript
用Python从零实现贝叶斯分类器的机器学习的教程
2015/03/31 Python
python3+PyQt5泛型委托详解
2018/04/24 Python
Python函数返回不定数量的值方法
2019/01/22 Python
Python第三方库h5py_读取mat文件并显示值的方法
2019/02/08 Python
python:HDF和CSV存储优劣对比分析
2020/06/08 Python
如何查看python关键字
2021/01/17 Python
css3中flex布局宽度不生效的解决
2020/12/09 HTML / CSS
Priority Pass机场贵宾室会籍计划:全球超过1200间机场贵宾室
2018/08/26 全球购物
Perfume’s Club英国官网:购买香水和护肤品
2019/11/02 全球购物
你的创业计划书怎样才能打动风投
2014/02/06 职场文书
人事行政专员岗位职责
2014/07/23 职场文书
2014年单位工作总结范文
2014/11/27 职场文书
合理化建议书
2015/02/04 职场文书
志愿者个人总结
2015/03/03 职场文书
三八节活动主持词
2015/07/04 职场文书
初中班主任培训心得体会
2016/01/07 职场文书