VueRouter导航守卫用法详解


Posted in Javascript onDecember 25, 2017

简介

主要用来通过跳转或取消的方式守卫导航。

例如判断登录信息:没登录全部跳到登录页。判断必要操作是否进行没进行的话中断跳转。

分为三大类:全局守卫、路由守卫、组件守卫

全局守卫

beforeEach
beforeResolve
afterEach

路由守卫

beforeEnter

组件守卫

beforeRouteEnter
  // 在渲染该组件的对应路由被 confirm 前调用
  // 不!能!获取组件实例 `this`
  // 因为当守卫执行前,组件实例还没被创建
  虽然无法直接获取组件实力
  但是我们可以通过next参数的回调函数获取到当前实例进行操作
  beforeRouteEnter: (to, from, next) => {
    next((vm) => {
      //vm就是当前组件实例
    });
  }
beforeRouteUpdate
  // 在当前路由改变,但是该组件被复用时调用
  // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
  // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
  // 可以访问组件实例 `this`
beforeRouteLeave
  // 导航离开该组件的对应路由时调用
  // 可以访问组件实例 `this`

参数介绍

这些导航守卫涉及到的参数:to、from、next

除了全局守卫的afterEach只有to和from外其余都有三个参数

(摘抄自官网)
to: Route: 即将要进入的目标 路由对象
from: Route: 当前导航正要离开的路由
next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。
  next(): 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是 confirmed (确认的)。
  next(false): 中断当前的导航。如果浏览器的 URL 改变了(可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。
  next('/') 或者 next({ path: '/' }): 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航。
  next(error): (2.4.0+) 如果传入 next 的参数是一个 Error 实例,则导航会被终止且该错误会被传递给 router.onError() 注册过的回调。

运行机制

VueRouter导航守卫用法详解

以上就是本次给大家介绍的关于VueRouter导航守卫的全部知识,希望我们整理的内容对你有用,感谢你对三水点靠木的支持。

Javascript 相关文章推荐
jquery改变disabled的boolean状态的三种方法
Dec 13 Javascript
JS+CSS实现弹出全屏灰黑色透明遮罩效果的方法
Dec 20 Javascript
Javascript实现Web颜色值转换
Feb 05 Javascript
深入理解(function(){... })();
Aug 16 Javascript
JS实现拖动滚动条评分的效果代码分享
Sep 29 Javascript
javaScript语法总结
Nov 25 Javascript
BootStrap中的Fontawesome 图标
May 25 Javascript
JS实现利用两个队列表示一个栈的方法
Dec 13 Javascript
在 React、Vue项目中使用SVG的方法
Feb 09 Javascript
浅谈webpack 自动刷新与解析
Apr 09 Javascript
关于layui 弹出层一闪而过就消失的解决方法
Sep 09 Javascript
Vue项目开发常见问题和解决方案总结
Sep 11 Javascript
基于zTree树形菜单的使用实例
Dec 25 #Javascript
利用jQuery+localStorage实现一个简易的计时器示例代码
Dec 25 #jQuery
用 Vue.js 递归组件实现可折叠的树形菜单(demo)
Dec 25 #Javascript
详解vue-cli之webpack3构建全面提速优化
Dec 25 #Javascript
jQuery EasyUI 选项卡面板tabs的使用实例讲解
Dec 25 #jQuery
zTree树形菜单交互选项卡效果的实现方法
Dec 25 #Javascript
jQuery EasyUI 折叠面板accordion的使用实例(分享)
Dec 25 #jQuery
You might like
关于php mvc开发模式的感想
2011/06/28 PHP
php输出指定时间以前时间格式的方法
2015/03/21 PHP
WordPress中用于创建以及获取侧边栏的PHP函数讲解
2015/12/29 PHP
完美解决phpdoc导出文档中@package的warning及Error的错误
2016/05/17 PHP
PHP使用pdo连接access数据库并循环显示数据操作示例
2018/06/05 PHP
基于jquery的表头固定的若干方法
2011/01/27 Javascript
jQuery编辑器KindEditor4.1.4代码高亮显示设置教程
2013/03/01 Javascript
jquery改变tr背景色的示例代码
2013/12/28 Javascript
jquery序列化form表单使用ajax提交后处理返回的json数据
2014/03/03 Javascript
jQuery实现新消息闪烁标题提示的方法
2015/03/11 Javascript
移动端界面的适配
2017/01/11 Javascript
Vue ElementUI之Form表单验证遇到的问题
2017/08/21 Javascript
11行JS代码制作二维码生成功能
2018/03/09 Javascript
百度小程序之间的页面通信过程详解
2019/07/18 Javascript
Vue指令之 v-cloak、v-text、v-html实例详解
2019/08/08 Javascript
原生javascript单例模式的应用实例分析
2020/02/23 Javascript
详解vue-flickity的fullScreen功能实现
2020/04/07 Javascript
vue created钩子函数与mounted钩子函数的用法区别
2020/11/05 Javascript
[04:40]2016个国际邀请赛中国区预选赛场地——华西村观战指南
2016/06/25 DOTA
Python基于smtplib实现异步发送邮件服务
2015/05/28 Python
JSONLINT:python的json数据验证库实例解析
2017/11/28 Python
Python利用pandas处理Excel数据的应用详解
2019/06/18 Python
使用python爬取微博数据打造一颗“心”
2019/06/28 Python
python 函数的缺省参数使用注意事项分析
2019/09/17 Python
Python 排序最长英文单词链(列表中前一个单词末字母是下一个单词的首字母)
2020/12/14 Python
EJB需直接实现它的业务接口或Home接口吗,请简述理由
2016/11/23 面试题
银行毕业实习自我鉴定
2013/09/19 职场文书
《陈毅探母》教学反思
2014/05/01 职场文书
2014年国庆节演讲稿精选范文1500字
2014/09/25 职场文书
工作失误检讨书范文
2015/01/26 职场文书
公司优秀员工推荐信
2015/03/24 职场文书
2015年小学校长工作总结
2015/05/19 职场文书
八一建军节主持词
2015/07/01 职场文书
利用Python实现模拟登录知乎
2022/05/25 Python
教你如何用cmd快速登录服务器
2022/06/10 Servers
MYSQL中文乱码问题的解决方案
2022/06/14 MySQL