Vue -- 项目报错整理(1):RangeError: Maximum call stack size exceeded
這幾天項目運行報了個錯: Uncaught RangeError: Maximum call stack size exceeded,剛開始看到 "returnNodeParameter",以為是 "returnNodeParameter" 方法報錯,但轉眼看到后面 "Maximum call stack size exceeded",就明白了,這明顯是 超過了最大堆棧量(堆棧溢出) 。
?
堆棧溢出的產生是由于過多的函數調用,導致調用堆棧無法容納這些調用的返回地址,一般容易在遞歸中產生。所以這種錯誤一般是在遞歸函數當中出現,結合報錯提示中提到的 returnNodeParameter方法,查看?returnNodeParameter方法自身以及 returnNodeParameter內其他調用方法中是否存在遞歸函數調用。自己寫的代碼,那些是遞歸函數那些不是,心里都有數,既然明確了是遞歸函數的鍋,那就從調用的遞歸函數中找原因就是。
產生錯誤原因:問題原因很簡單,在?if (temp[i].pid !== '0')?中將本該寫成??this.selectedNodePid?的誤寫成了 this.selectedNode,導致?this.selectedNodePid 在后續遞歸執行中一直得不到更新,永遠是最開始調用的值,從而遞歸循環一直轉不出來,導致無限循環,造成堆棧溢出。
,錯誤原因如圖所示。
歸根結底是參數和參數條件判斷的錯誤導致遞歸函數一直循環遞歸調用,無法停止,從而只有在超出瀏覽器最大堆棧量(內存溢出)時,瀏覽器拋出錯誤才能停止。
轉載于:https://www.cnblogs.com/donghuang/p/10558705.html
總結
以上是生活随笔為你收集整理的Vue -- 项目报错整理(1):RangeError: Maximum call stack size exceeded的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 179一个错误的认识
- 下一篇: 处理器管理与进程管理