美文网首页
浅谈vue路由守卫

浅谈vue路由守卫

作者: 欢宝吖_ | 来源:发表于2022-11-23 19:09 被阅读0次

路由守卫是什么?

路由守卫又称导航守卫,指的是路由在跳转前、中、后过程中的一些钩子函数,这些函数可以让你操作一些其他的事,常作用于某些后台管理系统在设置权限的时候,在实现路由跳转前校验是否有权限,有权限就可以通过,反之就会被执行其他操作,如返回登录页。

路由守卫的分类

一、全局守卫

  • 全局前置守卫beforeEach

在路由跳转前触发,这个钩子作用主要是用于登录验证,判断用户是否满足登录要求,满足就跳转到其他页面,不满足就强制跳转到登录页。

router.beforeEach((to, from, next) => {
})
  • 全局解析守卫beforeResolve

在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。

router.beforeResolve((to, from, next) => {
})
  • 全局后置守卫afterEach(参数中没有next)
router.afterEach((to, from) => {
})

二、组件内的守卫

  • beforeRouteEnter

不能访问 this,因为守卫在路由确认前被调用,组件还没有被创建

beforeRouteEnter (to, fromnext) {}
  • beforeRouteUpdate

在当前路由改变,但是该组件复用时调用,举例来说,对于一个带有动态数的路径 /foo/:id,在 /foo/1和 /foo/2 之间跳转的时候,由于会渲染同样的 Foo 组件因此组件实例会被复用。而这个就会在这个情况下被调用。

beforeRouteUpdate (to, from,next) {
  // 可以访问组件实例 `this`
}
  • beforeRouteLeave

这个离开守卫通常用来禁止用户在还未保存信息前突然离开。该导航可以通过 next(false) 来取消。

beforeRouteLeave (to, from,next) {
  // 导航离开该组件的对应路由时用
  // 可以访问组件实例 `this`
}

三、路由独享的守卫

  • beforeEnter

用法与全局守卫一致。只是,将其写进其中一个路由对象中,只在这个路由下起作用。

const router = new VueRouter({
  routes: [
    {
      path: '/foo',
      component: Foo,
      beforeEnter: (to, from, next) => {
        // ...
        // 只在foo路由下起作用
      }
    }
  ]
})

路由守卫的参数

1、to

  • 即将要跳转的路由
  • 相当于$router

2、from

  • 当前离开的路由

3、next()

以下是next()的常见的用法:

(1)next(),表示可以放行,跳转到需要跳转的路由

(2)next('路径'),表示强制跳转到某个路由。例如:next('/login')表示强制跳转到登录页

(3)next(false),中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。

项目中使用路由守卫

路由守卫.png

相关文章

  • 华云

    一,vue路由守卫的生命周期1,全局的前置路由守卫 router.beforeEach()2, 全局解析守卫 ...

  • react实现路由守卫

    与vue不同,vue直接使用beforeEach即可实现全局路由守卫等功能。react要实现路由守卫得自己配置。实...

  • vue-router 常见导航守卫

    全局守卫vue-router全局有三个守卫 路由独享守卫如果你不想全局配置守卫的话,你可以为某些路由单独配置守卫 ...

  • vue 路由导航白话全解析

    这里先放上官网的教程和说明:点击这里,vue导航守卫官方文档 路由守卫 路由守卫说白了就是路由拦截,在地址栏跳转之...

  • Vue导航守卫

    Vue导航守卫 理解 导航守卫也叫路由守卫,可以实时的监控路由的跳转过程,在路由的跳转的各个过程执行相应的操作,有...

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • 关于vue路由守卫做登陆状态判断的问题

    关于vue路由守卫做登陆状态判断的问题 直接上代码 // 全局路由守卫 router.beforeEach((to...

  • Vue路由/路由守卫

    一、前端路由和后端路由概念解释 二、路由的基本使用方式 三、常见引入路由组件的方式和区别 四、常见引入路由分类1....

  • Vue - 路由守卫(路由的生命周期)

    路由守卫是什么? 官方解释:“导航”表示路由正在发生改变。正如其名,vue-router提供的导航守卫主要用来通过...

  • vue-router进阶

    导航守卫 vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航(路由发生改变才会守卫)。参数 ...

网友评论

      本文标题:浅谈vue路由守卫

      本文链接:https://www.haomeiwen.com/subject/xrozxdtx.html