[Vue warn]: Unhandled error during execution -- 【vue bug】

昨天同事遇到一个问题反馈给我,加班到深夜也无法解决,今天忽然想到往往花费时间巨大的问题没有答案可能是最简单的原因,解决了写下来反思。

 

项目场景:

技术:Vue3 + TS + CompositionAPI

系统:无关

场景:在一个vue页面引用一个vue组件

 

问题描述:

问题现象:

重复引用首先出现警告如下:

 [Vue warn]: Unhandled error during execution of scheduler flush. This is likely a Vue internals bug. Please open an issue at https://new-issue.vuejs.org/?repo=vuejs/vue-next 

然后疯狂重复加载组件,直至浏览器崩溃。报错如下:

runtime-core.esm-bundler.js?5c40:819 Uncaught (in promise) RangeError: Maximum call stack size exceeded

截图:
在这里插入图片描述

在这里插入图片描述
 

原因分析:

最初的定位是代码问题,定时器或者一些自执行时间引起。走了弯路,万万没有想到生活给我上了一课。

其实就引入组件起名和页面起名一致引起,造成了循环引用死循环。

在这里插入图片描述

在这里插入图片描述

 

解决方案:

组件名和页面名区分开来。

 

反思

虽然代码不是我写的,却给我也上了一课,写代码要谨慎小心,养成好的习惯,减少犯错机会。

往往经过很长时间的解决问题才能记忆深刻。

帮别人解决问题的时候,问题花费很多时间没有分析出,是不是先排查下基础问题?

  • 17
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星宇大前端

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值