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 相关文章推荐
javascript管中窥豹 形参与实参浅析
Dec 17 Javascript
jquery.validate.js插件使用经验记录
Jul 02 Javascript
jQuery中removeProp()方法用法实例
Jan 05 Javascript
JavaScript实现将xml转换成html table表格的方法
Apr 17 Javascript
JavaScript中的Math.SQRT1_2属性使用简介
Jun 14 Javascript
基于jQuery实现放大镜特效
Oct 19 Javascript
通过jquery实现页面的动画效果(实例代码)
Sep 18 Javascript
jQuery中的一些小技巧
Jan 18 Javascript
原生js实现简单的Ripple按钮实例代码
Mar 24 Javascript
微信小程序实现文字从右向左无限滚动
Nov 18 Javascript
vue-cli创建的项目中的gitHooks原理解析
Feb 14 Javascript
简单了解JavaScript弹窗实现代码
May 07 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中static关键字原理的学习研究分析
2011/07/18 PHP
php时间戳转换的示例
2014/03/31 PHP
C#使用PHP服务端的Web Service通信实例
2014/04/08 PHP
destoon各类调用汇总
2014/06/20 PHP
百度地图经纬度转换到腾讯地图/Google 对应的经纬度
2015/08/28 PHP
Javascript----文件操作
2007/01/18 Javascript
将两个div左右并列显示并实现点击标题切换内容
2013/10/22 Javascript
jQuery中bind与live的用法及区别小结
2014/01/27 Javascript
JS+CSS实现经典的左侧竖向滑动菜单效果
2015/09/23 Javascript
jQuery实现边框动态效果的实例代码
2016/09/23 Javascript
利用vue实现模态框组件
2016/12/19 Javascript
ES6新增的math,Number方法
2017/08/06 Javascript
vue.js的手脚架vue-cli项目搭建的步骤
2017/08/30 Javascript
Popup弹出框添加数据实现方法
2017/10/27 Javascript
vue实现验证码输入框组件
2017/12/14 Javascript
jQuery与vue实现拖动验证码功能
2018/01/30 jQuery
详解用python实现简单的遗传算法
2018/01/02 Python
PyQt5每天必学之QSplitter实现窗口分隔
2018/04/19 Python
python版大富翁源代码分享
2018/11/19 Python
解决PyCharm控制台输出乱码的问题
2019/01/16 Python
Django shell调试models输出的SQL语句方法
2019/08/29 Python
需要知道的CSS3动画技术
2010/01/01 HTML / CSS
使用CSS3的背景渐变Text Gradient 创建文字颜色渐变
2014/08/19 HTML / CSS
AmazeUI中各种的导航式菜单与解决方法
2020/08/19 HTML / CSS
汽车维修专业毕业生的求职信分享
2013/12/04 职场文书
社区学习十八大感想
2014/01/22 职场文书
银行开业庆典方案
2014/02/06 职场文书
租房协议书范本
2014/04/09 职场文书
行政文员实习自我鉴定范文
2014/09/14 职场文书
小学生国庆65周年演讲稿范文(2篇)
2014/09/21 职场文书
2015年仓管员工作总结
2015/04/21 职场文书
七年级作文之我的梦想
2019/10/16 职场文书
MySQL中varchar和char类型的区别
2021/11/17 MySQL
使用Python开发冰球小游戏
2022/04/30 Python
Go语言测试库testify使用学习
2022/07/23 Golang
Redis实战之Lettuce的使用技巧详解
2022/12/24 Redis