Vue使用路由钩子拦截器beforeEach和afterEach监听路由


Posted in Javascript onNovember 16, 2020

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

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

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

两种函数:

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

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

全局钩子函数

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

// router.jsconst router = new Router({
 routes: [
  {
   path: '/',
   name: 'sideBar',
   component: sideBar,
   children:[
    {
     path:'/',
     name:'sort',
     component:sort
    },
    {
     path:'/addNewSort',
     name:'addNewSort',
     component:addNewSort
    },
    {
     path:'/notSend',
     name:'notSend',
     component:notSend
    },
    {
     path:'/sended',
     name:'sended',
     component:sended
    },
  }
 ]
})

router.beforeEach((to,from,next)=>{
 // console.log("to:",to);   // router即将进入的路由对象
 // console.log("from:",from); // 当前导航即将离开的路由
 // console.log("next:",next); // Function,进行管道中的一个钩子,如果执行完了,则导航的状态就是 confirmed (确认的);否则为false,终止导航。
 if(to.name=='notSend'){
  next({
   name:'sort'
  })
  return
 }
 next()
})

export default router

某个路由的钩子函数

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

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

路由组件的钩子

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

// *.vuebeforeRouteEnter
beforeRouteUpdate (2.2 新增)
beforeRouteLeave

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

beforeRouteLeave(to, from, next) {
  next()
},
beforeRouteEnter(to, from, next) {
  next()
},
beforeRouteUpdate(to, from, next) { // 用于相同路由组件的的参数更新
  next()
},
data:{},
method: {}

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

Javascript 相关文章推荐
学习YUI.Ext 第六天--关于树TreePanel(Part 2异步获取节点)
Mar 10 Javascript
javascript Xml增删改查(IE下)操作实现代码
Jan 30 Javascript
JavaScript保存并运算页面中数字类型变量的写法
Jul 06 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
Dec 24 Javascript
jquery实现右侧栏菜单选择操作
Mar 04 Javascript
详解AngularJS中ng-src指令的使用
Sep 07 Javascript
JavaScript实现经典排序算法之冒泡排序
Dec 28 Javascript
JavaScript中transform实现数字翻页效果
Mar 08 Javascript
es6学习之解构时应该注意的点
Aug 29 Javascript
vue Element-ui input 远程搜索与修改建议显示模版的示例代码
Oct 19 Javascript
Bootstrap的aria-label和aria-labelledby属性实例详解
Nov 02 Javascript
详解JavaScript 为什么要有 Symbol 类型?
Apr 03 Javascript
小程序实现密码输入框
Nov 16 #Javascript
vue 使用localstorage实现面包屑的操作
Nov 16 #Javascript
适用于 Vue 的播放器组件Vue-Video-Player操作
Nov 16 #Javascript
Vue中使用JsonView来展示Json树的实例代码
Nov 16 #Javascript
Vue 数据绑定的原理分析
Nov 16 #Javascript
Vue 使用iframe引用html页面实现vue和html页面方法的调用操作
Nov 16 #Javascript
Vue指令实现OutClick的示例
Nov 16 #Javascript
You might like
一个简洁的PHP可逆加密函数(分享)
2013/06/06 PHP
PHP中抽象类和抽象方法概念与用法分析
2016/05/24 PHP
解决Laravel5.2 Auth认证退出失效的问题
2019/10/14 PHP
PHP中迭代器的简单实现及Yii框架中的迭代器实现方法示例
2020/04/26 PHP
Javascript 布尔型分析
2008/12/22 Javascript
javascript json2 使用方法
2010/03/16 Javascript
如何让页面加载完成后执行js
2013/06/26 Javascript
jQuery源码解读之hasClass()方法分析
2015/02/20 Javascript
基于jquery实现图片上传本地预览功能
2016/01/08 Javascript
bootstrapValidator.min.js表单验证插件
2017/02/09 Javascript
JavaScript实现的鼠标响应颜色渐变效果完整实例
2017/02/18 Javascript
js实现显示手机号码效果
2017/03/09 Javascript
原生Aajax 和jQuery Ajax 写法个人总结
2017/03/24 jQuery
vue 使用ref 让父组件调用子组件的方法
2018/02/08 Javascript
Node.js的Koa实现JWT用户认证方法
2018/05/05 Javascript
Bootstrap实现前端登录页面带验证码功能完整示例
2020/03/26 Javascript
Vue 组件的挂载与父子组件的传值实例
2020/09/02 Javascript
[02:33]DOTA2亚洲邀请赛趣味视频之吐真话筒
2018/03/31 DOTA
Python random模块常用方法
2014/11/03 Python
使用Python来开发Markdown脚本扩展的实例分享
2016/03/04 Python
Python中的字符串查找操作方法总结
2016/06/27 Python
Python列表list解析操作示例【整数操作、字符操作、矩阵操作】
2017/07/25 Python
对python中数组的del,remove,pop区别详解
2018/11/07 Python
Python中函数参数匹配模型详解
2019/06/09 Python
Python3 实现串口两进程同时读写
2019/06/12 Python
python字典改变value值方法总结
2019/06/21 Python
使用keras2.0 将Merge层改为函数式
2020/05/23 Python
python如何随机生成高强度密码
2020/08/19 Python
基于python的opencv图像处理实现对斑马线的检测示例
2020/11/29 Python
Python实现淘宝秒杀功能的示例代码
2021/01/19 Python
好的自荐信的要求
2013/10/30 职场文书
公务员学习习总书记“三严三实”思想汇报
2014/09/19 职场文书
房屋分割离婚协议书范本
2014/12/01 职场文书
工作收入证明范本
2015/06/12 职场文书
MySQL8.0无法启动3534的解决方法
2021/06/03 MySQL
Java 通过手写分布式雪花SnowFlake生成ID方法详解
2022/04/07 Java/Android