zoukankan      html  css  js  c++  java
  • 使用Vue-Router的导航守卫-无限循环问题

    我在项目里面用到了的是全局守卫,beforeEach,方便管理
    不过遇到了一个问题,就是在beforeEach()中设置好判断条件后出现了无限循环的问题
    当时的代码如下:

    router.beforeEach((to, from, next) => {
        if (isLogin) {
          next()
        } else {
          console.log('测试')
          next('login')
        }
    })
    

    结果chrome的debug中看到:

    在这里插入图片描述

    这个问题我是这样理解的:
    next() 表示路由成功,直接进入to路由,不会再次调用router.beforeEach()
    next('login') 表示路由拦截成功,重定向至login,会再次调用router.beforeEach()
    也就是说beforeEach()必须调用next(),否则就会出现无限循环,next() 和 next('xxx') 是不一样的,区别就是前者不会再次调用router.beforeEach(),后者会!!!
    官网这样写的(主要是红线标记的那句!):
    在这里插入图片描述

    最终解决的代码如下:

    router.beforeEach((to, from, next) => {
        if (isLogin) {
          next()
        } else {
          if (to.name === 'login') {
            next()
          } else {
            console.log('测试')
            next('login')
          }
        }
    })
    

    觉得有帮助的小伙伴右上角点个赞~

    在这里插入图片描述

    扫描上方二维码关注我的订阅号~

    觉得有帮助的小伙伴点个赞~

  • 相关阅读:
    007 Java引用数据类型
    005 Java数组
    002 Java 引用数据类型示例
    001 Java入门和简介
    2.接口测试工具-Postman
    1、接口测试-前言
    测试工程师的进阶之路
    接口测试概述
    期末作品检查
    完成个人中心—导航标签
  • 原文地址:https://www.cnblogs.com/zheroXH/p/11690180.html
Copyright © 2011-2022 走看看