前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue | 路由守卫面试常考

Vue | 路由守卫面试常考

原创
作者头像
程序员海军
修改2022-02-15 11:15:46
9690
修改2022-02-15 11:15:46
举报
文章被收录于专栏:前端笔记ing前端笔记ing

Vue Router 路由守卫

导图目录

路由守卫分类 全局路由守卫 单个路由守卫 组件路由守卫 路由守卫执行的完整过程

<hr/>

路由守卫分类

全局路由 单个路由独享 组件内部路由

每个路由守卫的钩子函数都有 3 个参数:

to : 进入的目标路由from : 离开的路由next : 控制路由 在跳转时进行的操作,一定要执行。它有 4 个行为:next() : 钩子都执行完了,进入到下一个路由当中。next(false): 中断路由进入下一个路由。 next('/') : 根据你路由跳转判断条件来进入对应的路由, / 为路由的 pathnext(new Error) : 中断路由跳转,错误会被传递给 router.onError() 注册过的回调。

全局路由守卫

beforeEach(to,from, next) beforeResolve(to,from, next) afterEach(to,from)

全局路由直接挂载到 router 实例上。

代码语言:javascript
复制
//全局验证路由
const router = createRouter({
  history: createWebHashHistory(),
  routes
});

// 白名单, 不需要验证的路由
const whiteList = ['/','/register']

router.beforeEach((to,from,next)=>{
  if(whiteList.indexOf(to.path) === 0) {
    // 放行,进入下一个路由
    next()
  } else if(!(sessionStorage.getItem('token'))){
    next('/');     
  } else {
    next()
  }  
})
beforeEach

使用场景

路由跳转前触发

作用

常用于登录验证

beforeResolve

使用场景

在 beforeEach 和 组件内beforeRouteEnter 之后,afterEach之前调用。

afterEach

使用场景

发生在beforeEach和beforeResolve之后,beforeRouteEnter之前。 路由在触发后执行

单个路由独享

它只有一个 钩子函数, beforeEnter(to,from,next)

beforeEnter

使用场景

在beforeEach之后执行,和它功能一样 ,不怎么常用

代码语言:javascript
复制
      {
        path:'/superior',
        component: Superior,
        meta:{
          icon:'el-icon-s-check',
          title:'上级文件'
        },
        beforeEnter:(to,form,next) =>{
          
        }
      }

组件路由守卫

特点:

组件内执行的钩子函数

钩子函数:

beforeRouteEnter(to,from,next) beforeRouteUpdate(to,from,next) beforeRouteLeave(to,from,next)

beforeRouteEnter

使用场景:

路由进入之前调用。 不能获取组件 this 实例 ,因为路由在进入组件之前,组件实例还没有被创建。

执行顺序

beforeEach 和独享守卫beforeEnter之后,全局beforeResolve和全局afterEach之前调用.

beforeRouteUpdate

使用场景:

在当前路由改变时,并且该组件被复用时调用,可以通过this访问实例。 当前路由query变更时,该守卫会被调用。

beforeRouteLeave

使用场景:

导航离开该组件的对应路由时调用,可以访问组件实例this

路由守卫执行的完整过程

导航被触发 执行 组件内部路由守卫: beforeRouteLeave 执行 全局路由守卫 beforeEach 在重用组件内部路由守卫钩子 beforeRouteUpdate 执行 路由中的钩子 beforeEnter 在被激活的组件里调用 beforeRouteEnter 执行 全局的 beforeResolve 守卫 。 执行 全局的 afterEach 钩子 beforeCreate created beforeMount mounted 执行 beforeRouteEnter的next的回调 ,创建好的组件实例会作为回调函数的参数传入。

Vue  路 由 守  卫    前端自学社区.png
Vue 路 由 守 卫 前端自学社区.png

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vue Router 路由守卫
    • 导图目录
      • 路由守卫分类
        • 全局路由守卫
          • beforeEach
          • beforeResolve
          • afterEach
        • 单个路由独享
          • beforeEnter
        • 组件路由守卫
          • beforeRouteEnter
          • beforeRouteUpdate
          • beforeRouteLeave
        • 路由守卫执行的完整过程
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档