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 相关文章推荐
jQuery 页面载入进度条实现代码
Feb 08 Javascript
jQuery函数的等价原生函数代码示例
May 27 Javascript
jquery实现在光标位置插入内容的方法
Feb 05 Javascript
jquery中ajax处理跨域的三大方式
Jan 05 Javascript
深入理解jQuery事件绑定
Jun 02 Javascript
js数组的五种迭代方法及两种归并方法(推荐)
Jun 14 Javascript
AngularJs 国际化(I18n/L10n)详解
Sep 01 Javascript
浅谈js中同名函数和同名变量的执行问题
Feb 12 Javascript
vue-cli+webpack在生成的项目中使用bootstrap实例代码
May 26 Javascript
webpack中的热刷新与热加载的区别
Apr 09 Javascript
Node.js Koa2使用JWT进行鉴权的方法示例
Aug 17 Javascript
解决layer.confirm选择完之后消息框不消失的问题
Sep 16 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
深入理解ob_flush和flush的区别(ob_flush()与flush()使用方法)
2013/02/06 PHP
解析php中获取系统信息的方法
2013/06/25 PHP
PHP的变量类型和作用域详解
2014/03/12 PHP
适用于抽奖程序、随机广告的PHP概率算法实例
2014/04/09 PHP
PHP Curl出现403错误的解决办法
2014/05/29 PHP
PHP响应post请求上传文件的方法
2015/12/17 PHP
php实现大文件断点续传下载实例代码
2019/10/01 PHP
清华大学出版的事半功倍系列 javascript全部源代码
2007/05/04 Javascript
跟着JQuery API学Jquery 之三 筛选
2010/04/09 Javascript
最新的10款jQuery内容滑块插件分享
2011/09/18 Javascript
JavaScript实现GriwView单列全选(自写代码)
2013/05/13 Javascript
jquery 绑定回车动作扑捉回车键触发的事件
2014/03/26 Javascript
使用纯javascript实现经典扫雷游戏
2015/04/23 Javascript
实例讲解Jquery中隐藏hide、显示show、切换toggle的用法
2016/05/13 Javascript
javascript表单控件实例讲解
2016/09/13 Javascript
webpack打包后直接访问页面图片路径错误的解决方法
2017/06/17 Javascript
Vue-Cli中自定义过滤器的实现代码
2017/08/12 Javascript
vue结合Echarts实现点击高亮效果的示例
2018/03/17 Javascript
webpack4之SplitChunksPlugin使用指南
2018/06/12 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
详解mpvue小程序中怎么引入iconfont字体图标
2018/10/01 Javascript
webpack-mvc 传统多页面组件化开发详解
2019/05/07 Javascript
jQuery实现简易QQ聊天框
2020/02/10 jQuery
vue+iview实现文件上传
2020/11/17 Vue.js
[06:53]DOTA2每周TOP10 精彩击杀集锦vol.3
2014/06/25 DOTA
基于pandas中expand的作用详解
2019/12/17 Python
Python3.9.1中使用split()的处理方法(推荐)
2021/02/07 Python
Arti-shopping中文官网:大型海外商品一站式直邮平台
2020/03/23 全球购物
轻金属冶金专业毕业生自荐信
2013/11/02 职场文书
历史专业毕业生的自我鉴定
2013/11/15 职场文书
音乐学个人的自荐书范文
2013/11/26 职场文书
职业生涯规划书的格式
2013/12/29 职场文书
励志广播稿300字(5篇)
2014/09/15 职场文书
小学生毕业评语
2014/12/26 职场文书
收入证明怎么写
2015/06/12 职场文书
引用计数法和root搜索算法以及JVM中判定对象需要回收的方法
2022/04/19 Java/Android