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 相关文章推荐
在IE中调用javascript打开Excel的代码(downmoon原作)
Apr 02 Javascript
最简单的jQuery程序 入门者学习
Jul 09 Javascript
Jquery颜色选择器ColorPicker实现代码
Nov 14 Javascript
ajax读取数据后使用jqchart显示图表的方法
Jun 10 Javascript
JS+CSS实现的经典tab选项卡效果代码
Sep 16 Javascript
用NODE.JS中的流编写工具是要注意的事项
Mar 01 Javascript
js常用DOM方法详解
Feb 04 Javascript
angular十大常见问题
Mar 07 Javascript
基于Bootstrap框架实现图片切换
Mar 10 Javascript
使用js获取伪元素的content实例
Oct 24 Javascript
微信小程序利用swiper+css实现购物车商品删除功能
Mar 06 Javascript
jQuery实现推拉门效果
Oct 19 jQuery
基于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的面向对象编程
2006/10/09 PHP
PHP开发环境配置(MySQL数据库安装图文教程)
2010/04/28 PHP
探讨file_get_contents与curl效率及稳定性的分析
2013/06/06 PHP
PHP的Socket网络编程入门指引
2015/08/11 PHP
Yii2中使用join、joinwith多表关联查询
2016/06/30 PHP
默认让页面的第一个控件选中的javascript代码
2009/12/26 Javascript
基于jQuery的让非HTML5浏览器支持placeholder属性的代码
2011/05/24 Javascript
动态加载jquery库的方法
2014/02/12 Javascript
JavaScript中判断变量是数组、函数或是对象类型的方法
2015/02/25 Javascript
第八篇Bootstrap下拉菜单实例代码
2016/06/21 Javascript
angularjs 中$apply,$digest,$watch详解
2016/10/13 Javascript
canvas滤镜效果实现代码
2017/02/06 Javascript
vue生成token保存在客户端localStorage中的方法
2017/10/25 Javascript
解决vue中对象属性改变视图不更新的问题
2018/02/23 Javascript
vue 组件高级用法实例详解
2018/04/11 Javascript
微信小程序之自定义组件的实现代码(附源码)
2018/08/02 Javascript
基于Nodejs的Tcp封包和解包的理解
2018/09/19 NodeJs
VueJS 组件参数名命名与组件属性转化问题
2018/12/03 Javascript
LayUi数据表格自定义赋值方式
2019/10/26 Javascript
JS实现动态无缝轮播
2020/01/11 Javascript
uni-app微信小程序登录授权的实现
2020/05/22 Javascript
python调用Moxa PCOMM Lite通过串口Ymodem协议实现发送文件
2014/08/15 Python
使用Python的Scrapy框架编写web爬虫的简单示例
2015/04/17 Python
在Python上基于Markov链生成伪随机文本的教程
2015/04/17 Python
python石头剪刀布小游戏(三局两胜制)
2021/01/20 Python
利用pyinstaller打包exe文件的基本教程
2019/05/02 Python
Selenium webdriver添加cookie实现过程详解
2020/08/12 Python
python爬虫beautifulsoup解析html方法
2020/12/07 Python
CSS3实现的炫酷菜单代码分享
2015/03/12 HTML / CSS
HTML5去掉输入框type为number时的上下箭头的实现方法
2020/01/03 HTML / CSS
Canal官网:巴西女性时尚品牌
2019/10/16 全球购物
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
小学生开学第一课活动方案
2014/03/27 职场文书
2016年重阳节慰问信
2015/12/01 职场文书
Nginx进程调度问题详解
2021/09/25 Servers
Win11显卡控制面板打开显卡设置方法
2022/04/20 数码科技