小言_互联网的博客

vue3的七种路由守卫使用

461人阅读  评论(0)

路由守卫有哪几种?

        路由守卫(导航守卫)分为三种:全局守卫(3个)、路由独享守卫(1个)、组件的守卫(3个)。

路由守卫的三个参数

to:要跳转到的目标路由

from:从当前哪个路由进行跳转

next:不做任何阻拦,直接通行

注意: 必须要确保 next函数 在任何给定的导航守卫中都被调用过一次。它可以出现多次,但是只能在所有的逻辑路径都不重叠的情况下,否则会报错。 案例:


  
  1. router. beforeEach( (to, from, next) => {
  2. if (to. name !== 'Login' && !isAuthenticated) next({ name: 'Login' })
  3. else next()
  4. })

一、全局路由守卫

1.使用方式:main.js中配置,在路由跳转前触发,这个钩子作用主要是用于登录验证,也就是路由还没跳转提前告知,以免跳转了再通知就为时已晚。

2.代码:

router.beforeEach((to,from,next)=>{})

3.例子:做登录判断


  
  1. router. beforeEach( (to,from,next)=>{
  2. if(to. path == '/login' || to. path == '/register'){
  3. next();
  4. } else{
  5. alert( '您还没有登录,请先登录');
  6. next( '/login');
  7. }
  8. })

二、全局后置守卫

1.使用方式:main.js中配置,和beforeEach相反,它是在路由跳转完成后触发,它发生在beforeEach和beforeResolve之后,beforeRouteEnter(组件内守卫)之前。钩子不会接受next函数也不会改变导航本身。

2.代码:

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

三、全局解析守卫

1.使用方式:main.js中配置,这个钩子和beforeEach类似,也是路由跳转前触发,区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,即在 beforeEach 和 组件内beforeRouteEnter 之后,afterEach之前调用

2.代码:

router.beforeResolve((to,from,next)=>{})

四、组件内守卫

  1. beforeRouteEnter(to, from, next)
    1. 1.使用方式:在组件模板中使用,跟methods: {}等同级别书写,组件路由守卫是写在每个单独的vue文件里面的路由守卫。
    2. 代码:
      
            
      1. beforeRouteEnter( to, from, next) {
      2. // 在组件生命周期beforeCreate阶段触发
      3. console. log( '组件内路由前置守卫 beforeRouteEnter', this) // 访问不到this
      4. next( (vm) => {
      5. console. log( '组件内路由前置守卫 vm', vm) // vm 就是this
      6. })
      7. },
  2. beforeRouteUpdate(to, from, next)

    1. 使用方式:在组件模板中使用,跟methods: {}等同级别书写,组件路由守卫是写在每个单独的vue文件里面的路由守卫。
    2. 代码:
      
            
      1. beforeRouteUpdate (to, from, next) {
      2. // 同一页面,刷新不同数据时调用,
      3. // 可以访问组件实例
      4. }
  3. beforeRouteLeave(to, from, next)

    1. 使用方式:在组件模板中使用,跟methods: {}等同级别书写,组件路由守卫是写在每个单独的vue文件里面的路由守卫。
    2. 代码:

  
  1. beforeRouteLeave (to, from, next) {
  2. // 导航离开该组件的对应路由时调用
  3. // 可以访问组件实例
  4. }

 五、路由独享守卫

  1.  使用方式:在router.js中使用,路由独享守卫是在路由配置页面单独给路由配置的一个守卫。
  2. 代码:
    
        
    1. const router = new VueRouter({
    2. routes: [
    3. {
    4. path: '/foo',
    5. component: Foo,
    6. beforeEnter: (to, from, next) => {
    7. // ...
    8. }
    9. }
    10. ]
    11. })


转载:https://blog.csdn.net/qq_43474235/article/details/129111048
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场