vue报错--Maximum call stack size exceeded超出最大调用堆栈大小,已解决

本文探讨了MaximumCallStackExceeded错误的原因及解决方案,主要分析了递归函数错误、路由拦截器问题和重定向错误,并提供了具体修正案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Maximum call stack size exceeded错误描述

浏览器错误提示
其实就是超出最大调用堆栈大小,查了很长时间,总结解决方法如下几种:

1、最常见的原因就是:递归函数出错

检查递归函数是否具有停止调用的判断条件,解决后,就不会有堆栈溢出了。

2、路由拦截出错

问题代码如下:想实现的是,路由拦截,不允许乱跳转页面

router.beforeEach((to, from, next) => {
  if (to.path === '/login') next()
  const tokenStr = window.sessionStorage.getItem('token')
  if (!tokenStr) return next('/login')
  next()
})

解决如下:

router.beforeEach((to, from, next) => {
  if (to.path === '/login') next()
  const tokenStr = window.sessionStorage.getItem('token')
  // 增加判断条件
  if (!tokenStr && to.path !== '/login') return next('/login')
  next()
})
3、如果没有递归模块,查看路由拦截器重定向错误

如:想法是访问不存在的页面,跳转到404页面

{ path: '*', redirect: '/404' }

错误描述:页面 /404 在路由里面没有配置,故引发出错
解决:使用路由时,先配置注册这个页面

内容持续更新中…
lvan学习笔记-文章内容仅个人观点
2020.5.24

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值