vue 下一种引起Maximum call stack size exceeded的情况
项目场景:项目中用到vue,其中有一段业务需要写递归函数问题描述写完函数运行的时候一直报Maximum call stack size exceeded,从字面上理解是栈溢出了,要么是递归太深,要么是栈内函数传参太大。原因分析:根据栈溢出的原因排查1、我的递归不是很深只有三四层,应该不会是太深这个原因2、递归函数传参的问题,我项目中用到vue,为了防止在箭头函数内出现this指向的问题,我把thi
·
项目场景:
项目中用到vue,其中有一段业务需要写递归函数
问题描述
写完函数运行的时候一直报Maximum call stack size exceeded,从字面上理解是栈溢出了,要么是递归太深,要么是栈内函数传参太大。
原因分析:
根据栈溢出的原因排查
1、我的递归不是很深只有三四层,应该不会是太深这个原因
2、递归函数传参的问题,我项目中用到vue,为了防止在箭头函数内出现this指向的问题,我把this作为参数传到递归函数内。可能是this这个参数过大,导致栈溢出。经过查找资料,箭头函数内的this,是访问外层作用域中的this。也就是说我不需要把this作为参数传递过去
test(val, val1,that)
解决方案:
解决方案就是,把this这个参数从递归函数中的参数列表中去掉,问题解决。
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)