Vuerouter的beforeEach与afterEach钩子函数的区别


Posted in Javascript onDecember 26, 2018

在路由跳转的时候,我们需要一些权限判断或者其他操作。这个时候就需要使用路由的钩子函数。

定义:路由钩子主要是给使用者在路由发生变化时进行一些特殊的处理而定义的函数。

总体来讲vue里面提供了三大类钩子,两种函数
1、全局钩子
2、某个路由的钩子
3、组件内钩子

两种函数:

1、Vue.beforeEach(function(to,form,next){}) /*在跳转之前执行*/

2.Vue.afterEach(function(to,form))/*在跳转之后判断*/

全局钩子函数

顾名思义,它是对全局有效的一个函数

router.beforeEach((to, from, next) => {

  let token = router.app.$storage.fetch("token");

  let needAuth = to.matched.some(item => item.meta.login);

  if(!token && needAuth) return next({path: "/login"});

  next();

});

beforeEach函数有三个参数:

  • to:router即将进入的路由对象
  • from:当前导航即将离开的路由
  • next:Function,进行管道中的一个钩子,如果执行完了,则导航的状态就是 confirmed (确认的);否则为false,终止导航。

afterEach函数不用传next()函数

某个路由的钩子函数

顾名思义,它是写在某个路由里头的函数,本质上跟组件内函数没有区别。

const router = new VueRouter({
 routes: [
  {
   path: '/login',
   component: Login,
   beforeEnter: (to, from, next) => {
    // ...
   },
   beforeLeave: (to, from, next) => {
    // ...
   }
  }
 ]
})

路由组件的钩子

注意:这里说的是路由组件!

路由组件 属于 组件,但组件 不等同于 路由组件!所谓的路由组件:直接定义在router中component处的组件。如:

var routes = [
  {
  path:'/home',
  component:home,
  name:"home"
  }
]

在子组件中调用路由的钩子函数时无效的。

在官方文档上是这样定义的:

可以在路由组件内直接定义以下路由导航钩子

  • beforeRouteEnter
  • beforeRouteUpdate (2.2 新增)
  • beforeRouteLeave

这里简单说下钩子函数的用法:它是和data,methods平级的。

beforeRouteLeave(to, from, next) {
  next()
},
beforeRouteEnter(to, from, next) {
  next()
},
beforeRouteUpdate(to, from, next) {
  next()
},
data:{},
method: {}

PS:在使用vue-router beforeEach钩子时,你也许会遇到如下问题:

源码:

router.beforeEach((to, from, next) => {
//判断登录状态简单实例
var userInfo = window.localStorage.getItem('token');
if (userInfo) {
next();
} else {
next('/login');
}
})

然后你会发现出现如下错误:出现dead loop错误

Vuerouter的beforeEach与afterEach钩子函数的区别

解决方案:

router.beforeEach((to, from, next) => {
var userInfo = window.localStorage.getItem('token');//获取浏览器缓存的用户信息
if(userInfo){ //如果有就直接到首页咯
next();
} else {
if(to.path=='/login'){ //如果是登录页面路径,就直接next()
next();
} else { //不然就跳转到登录;
next('/login');
}

}
})

解决思路:

排除此时地址 = 转向的地址 的情况,避免dead loop, 问题很简单,但一不小心就入坑了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
索趣科技的答案
Feb 07 Javascript
JQuery验证jsp页面属性是否为空(实例代码)
Nov 08 Javascript
node.js中的path.sep方法使用说明
Dec 08 Javascript
JavaScript中的this关键字使用方法总结
Mar 13 Javascript
详解前端构建工具gulpjs的使用介绍及技巧
Jan 19 Javascript
详解vue-resource promise兼容性问题
Jun 20 Javascript
AngularJS 购物车全选/取消全选功能的实现方法
Aug 14 Javascript
详解关于react-redux中的connect用法介绍及原理解析
Sep 11 Javascript
AngularJS实现图片上传和预览功能的方法分析
Nov 08 Javascript
Vue实现移动端左右滑动效果的方法
Nov 27 Javascript
利用d3.js力导布局绘制资源拓扑图实例教程
Jan 08 Javascript
JS将时间秒转换成天小时分钟秒的字符串
Jul 10 Javascript
使用Sonarqube扫描Javascript代码的示例
Dec 26 #Javascript
angular6的table组件开发的实现示例
Dec 26 #Javascript
详解VUE里子组件如何获取父组件动态变化的值
Dec 26 #Javascript
JavaScript基础之静态方法和实例方法分析
Dec 26 #Javascript
微信小程序实现文字跑马灯
May 26 #Javascript
基于JavaScript canvas绘制贝塞尔曲线
Dec 25 #Javascript
基于js Canvas实现二次贝塞尔曲线
Dec 25 #Javascript
You might like
PHP常用代码大全(新手入门必备)
2010/06/29 PHP
那些年一起学习的PHP(三)
2012/03/22 PHP
PHP的反射类ReflectionClass、ReflectionMethod使用实例
2014/08/05 PHP
在Linux系统下一键重新安装WordPress的脚本示例
2015/06/30 PHP
老生常谈文本文件和二进制文件的区别
2017/02/27 PHP
JavaScript Konami Code 实现代码
2009/07/29 Javascript
js实现从中间开始往上下展开网页窗口的方法
2015/03/02 Javascript
基于jQuery通过jQuery.form.js插件使用ajax提交form表单
2015/08/17 Javascript
jQuery实现的仿select功能代码
2015/08/19 Javascript
基于jQuery通过jQuery.form.js插件实现异步上传
2015/12/13 Javascript
AngularJS中指令的四种基本形式实例分析
2016/11/22 Javascript
js利用for in循环获取 一个对象的所有属性以及值的实例
2017/03/30 Javascript
jQuery滑动到底部加载下一页数据的实例代码
2017/05/22 jQuery
jQuery实现经典的网页3D轮播图封装功能【附源码下载】
2019/02/15 jQuery
解决layui table表单提示数据接口请求异常的问题
2019/09/24 Javascript
JS 事件机制完整示例分析
2020/01/15 Javascript
JavaScript中如何调用Java方法
2020/09/16 Javascript
手写Vue源码之数据劫持示例详解
2021/01/04 Vue.js
Python开发常用的一些开源Package分享
2015/02/14 Python
Python中使用PyQt把网页转换成PDF操作代码实例
2015/04/23 Python
python字符串循环左移
2019/03/08 Python
利用python、tensorflow、opencv、pyqt5实现人脸实时签到系统
2019/09/25 Python
使用pytorch实现可视化中间层的结果
2019/12/30 Python
Python面向对象程序设计之继承、多态原理与用法详解
2020/03/23 Python
Django实现将一个字典传到前端显示出来
2020/04/03 Python
tensorflow与numpy的版本兼容性问题的解决
2021/01/08 Python
英国领先的酒类网上商城:TheDrinkShop
2017/03/16 全球购物
英国可持续奢侈品包包品牌:Elvis & Kresse
2018/08/05 全球购物
办公室助理岗位职责
2013/12/25 职场文书
爱岗敬业演讲稿
2014/05/05 职场文书
小学先进集体事迹材料
2014/05/31 职场文书
幼儿园植树节活动总结
2014/07/04 职场文书
反四风对照检查材料思想汇报
2014/09/16 职场文书
师德师风事迹材料
2014/12/20 职场文书
投诉信格式范文
2015/07/02 职场文书
《游戏公平》教学反思
2016/02/20 职场文书