vue-router使用beforeEach导致Maximum call stack size exceeded问题

错误写法

router.beforeEach((to, from, next) => {
  var token = sessionStorage.getItem('token')
  if (!token) {
      next({ path: '/login' })
  } else {
    next()
  }
})

正确写法

router.beforeEach((to, from, next) => {
  var token = sessionStorage.getItem('token')
  if (!token) {
    if (to.path === '/login' || to.path === '/') {
      next()
    } else {
      next({ path: '/login' })
    }
  } else {
    next()
  }
})

next带参会重新回到beforeEach,所以还需要进行一步判断


版权声明:本文为a7442358原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。