关于Vue Router中路由守卫的应用及在全局导航守卫中检查元字段的方法


Posted in Javascript onDecember 09, 2018

 #在切换路由时,组件会被复用,不过,这也意味着组件的生命周期钩子不会再被调用。

 解决办法有两种,1简单地 watch (监测变化) $route 对象:

const User = {
 template: '...',
 watch: {
  '$route' (to, from) {
   // 对路由变化作出响应...
  }
 }
}

2.使用 2.2 中引入的 beforeRouteUpdate 导航守卫:

const User = {
 template: '...',
 beforeRouteUpdate (to, from, next) {
  // react to route changes...
  // don't forget to call next()
 }
}

#全局守卫

你可以使用 router.beforeEach 注册一个全局前置守卫:

const router = new VueRouter({ ... })
router.beforeEach((to, from, next) => {
 // ...
})

•to: Route: 即将要进入的目标 路由对象

•from: Route: 当前导航正要离开的路由

•next: Function: 一定要调用该方法来 resolve 这个钩子

#全局解析守卫

在 2.5.0+ 你可以用 router.beforeResolve 注册一个全局守卫。这和 router.beforeEach 类似,区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。

#全局后置钩子

你也可以注册全局后置钩子,然而和守卫不同的是,这些钩子不会接受 next 函数也不会改变导航本身:

router.afterEach((to, from) => {
 // ...
})

#路由独享的守卫

你可以在路由配置上直接定义 beforeEnter 守卫

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

这些守卫与全局前置守卫的方法参数是一样的。

#组件内的守卫

你可以在路由组件内直接定义以下路由导航守卫:

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

beforeRouteEnter 守卫 不能 访问 this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。

不过,你可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。

export default {
  data(){
    return {
       num: 18
    }
  },
  beforeRouteEnter(to, from, next){
    next(vm=>{
      vm.num=22;
    })
  }
}

注意 beforeRouteEnter 是支持给 next 传递回调的唯一守卫。对于 beforeRouteUpdate 和 beforeRouteLeave 来说,this 已经可用了,所以不支持传递回调,因为没有必要了

#完整的导航解析流程

1.导航被触发。
2.在失活的组件里调用离开守卫。
3.调用全局的 beforeEach 守卫。
4.在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
5.在路由配置里调用 beforeEnter。
6.解析异步路由组件。
7.在被激活的组件里调用 beforeRouteEnter。
8.调用全局的 beforeResolve 守卫 (2.5+)。
9.导航被确认。
10.调用全局的 afterEach 钩子。
11.触发 DOM 更新。
12.用创建好的实例调用 beforeRouteEnter 守卫中传给 next 的回调函数。

#在全局导航守卫中检查元字段

router.beforeEach((to, from, next) => {
 if (to.matched.some(record => record.meta.requiresAuth)) {
  //如果路由中有meta的requireAuth,且为true,就不进行登录验证,否则进行登录验证
  if (!auth.loggedIn()) {
   next({
    path: '/login',
    query: { redirect: to.fullPath }
   })
  } else {
   next()
  }
 } else {
  next() // 确保一定要调用 next()
 }
})

一个路由匹配到的所有路由记录会暴露为 $route 对象 (还有在导航守卫中的路由对象) 的 $route.matched 数组。因此,我们需要遍历 $route.matched 来检查路由记录中的 meta 字段。

注:1、meta 字段就是路由元信息字段,requiresAuth 是自己起的字段名称,用来标记这个路由信息是否需要检测,true 表示要检测,false 表示不需要检测(这个名称随便起,比如我自己的就起的 requiresId,建议起个有意义的名称)

2、if (to.matched.some(record => record.meta.requiresAuth) ),如果对这类写法不熟悉,可以去看看es6的箭头函数,这句话就是返回遍历的某个路由对象,我们定义为为record,检测这个对象是否拥有meta这个对象,如果有meta这个对象,检测它的meta对象是不是有requiresAuth这个属性,且为true,如果满足上述条件,就确定了是这个/foo/bar路由。

3、some() 方法测试数组中的某些元素是否通过了指定函数的测试。语法:arr.some(callback[, thisArg]);

some 为数组中的每一个元素执行一次 callback 函数,直到找到一个使得 callback 返回一个“真值”(即可转换为布尔值 true 的值)。如果找到了这样一个值,some 将会立即返回 true。否则,some 返回 false。callback 只会在那些”有值“的索引上被调用,不会在那些被删除或从来未被赋值的索引上调用。

 

 callback 被调用时传入三个参数:元素的值,元素的索引,被遍历的数组。

4、vue-router路由元信息说白了就是通过meta对象中的一些属性来判断当前路由是否需要进一步处理,如果需要处理,按照自己想要的效果进行处理即可!

总结

以上所述是小编给大家介绍的关于Vue Router中路由守卫的应用及在全局导航守卫中检查元字段的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
麻雀虽小五脏俱全 Dojo自定义控件应用
Sep 04 Javascript
jQuery弹出层始终垂直居中相对于屏幕或当前窗口
Apr 01 Javascript
兼容所有浏览器的js复制插件Zero使用介绍
Mar 19 Javascript
jQuery给元素添加样式的方法详解
Dec 30 Javascript
JavaScript中return用法示例
Nov 29 Javascript
JavaScript实现一个空中避难的小游戏
Jun 06 Javascript
微信小程序 地图map实例详解
Jun 07 Javascript
集合Bootstrap自定义confirm提示效果
Sep 19 Javascript
原生JS实现的跳一跳小游戏完整实例
Jan 27 Javascript
vue实现中部导航栏布局功能
Jul 30 Javascript
Vue过渡效果之CSS过渡详解(结合transition,animation,animate.css)
Feb 05 Javascript
json.stringify()与json.parse()的区别以及用处
Jan 25 Javascript
vue打包之后生成一个配置文件修改接口的方法
Dec 09 #Javascript
基于Vue-Cli 打包自动生成/抽离相关配置文件的实现方法
Dec 09 #Javascript
JS数组去重的6种方法完整实例
Dec 08 #Javascript
原生JS实现的放大镜特效示例【测试可用】
Dec 08 #Javascript
JS实现的小火箭发射动画效果示例
Dec 08 #Javascript
jQuery时间戳和日期相互转换操作示例
Dec 07 #jQuery
ES6的Fetch异步请求的实现方法
Dec 07 #Javascript
You might like
WHOIS类的修改版
2006/10/09 PHP
PHP中绘制图像的一些函数总结
2014/11/19 PHP
基于ThinkPHP实现批量删除
2015/12/18 PHP
Laravel使用支付宝进行支付的示例代码
2017/08/16 PHP
善用事件代理,警惕闭包的性能陷阱。
2011/01/20 Javascript
JQUERY dialog的用法详细解析
2013/12/19 Javascript
JS文本获得焦点清除文本文字的示例代码
2014/01/13 Javascript
理运用命名空间让js不产生冲突避免全局变量的泛滥
2014/06/15 Javascript
JavaScript数组迭代器实例分析
2015/06/09 Javascript
JQuery入门基础小实例(1)
2015/09/17 Javascript
微信小程序 富文本转文本实例详解
2016/10/24 Javascript
jQuery实现圣诞节礼物传送(花式轮播)
2016/12/25 Javascript
JavaScript 详解预编译原理
2017/01/22 Javascript
React服务端渲染(总结)
2017/07/01 Javascript
Node.JS循环删除非空文件夹及子目录下的所有文件
2018/03/12 Javascript
jQuery each和js forEach用法比较
2019/02/27 jQuery
小程序实现搜索框
2020/06/19 Javascript
Handtrack.js库实现实时监测手部运动(推荐)
2021/02/08 Javascript
python获取远程图片大小和尺寸的方法
2015/03/26 Python
python对html代码进行escape编码的方法
2015/05/04 Python
python执行子进程实现进程间通信的方法
2015/06/02 Python
Python实现桶排序与快速排序算法结合应用示例
2017/11/22 Python
Python使用Scrapy保存控制台信息到文本解析
2017/12/27 Python
python文件路径操作方法总结
2020/12/21 Python
pycharm 关闭search everywhere的解决操作
2021/01/15 Python
DJI大疆无人机官方商城:全球领先的无人飞行器研发和生产商
2016/12/21 全球购物
英国在线汽车和面包车零件商店:Car Parts 4 Less
2018/08/15 全球购物
洲际酒店集团英国官网:IHG英国
2019/07/10 全球购物
2014年道德讲堂实施方案
2014/03/05 职场文书
保密承诺书范文
2014/03/27 职场文书
银行进社区活动总结
2014/07/07 职场文书
党员年终个人总结
2015/02/14 职场文书
上市公司董事长岗位职责
2015/04/16 职场文书
win10下go mod配置方式
2021/04/25 Golang
php实现自动生成验证码的实例讲解
2021/11/17 PHP
win10系统xps文件怎么打开?win10打开xps文件的两种操作方法
2022/07/23 数码科技