setTimeout causes stack overflow(SetTimeout导致堆栈溢出)
本文介绍了SetTimeout导致堆栈溢出的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有以下代码。它会导致堆栈溢出异常。
知道我做错了什么吗?
var myApi = {
rawData: null,
initData: function() {
// ajax call to get data and populate myApi.rawData, max 10 seconds
},
waitForRawData: function(callback) {
if(myApi.rawData === null || myApi.rawData.length ===0) {
window.setTimeout(myApi.waitForRawData(callback),1000); // complain this line stack overflow
}else{
callback();
}
},
updateHtmlWithNewData: function() {
// base on myApi.rawData update html element
},
workflow: function() { // this function call is invoke from page
myApi.initData();
myApi.waitForRawData(myApi.updateHtmlWithNewData);
}
}
推荐答案
您有一个无限循环。
setTimeout
期望第一个参数是回调函数--您实际上是在当场调用waitForRawData
函数。它立即再次调用它自己,它立即再次调用它自己,这...你明白了。
执行此操作:
window.setTimeout(function() { myApi.waitForRawData(callback) },1000);
当您将其作为函数传递时,超时器可以在您告诉它的任何时候调用它--在您的情况下,是在一秒钟之后。在不使用包装函数的情况下执行此操作将立即调用相同的代码。
这篇关于SetTimeout导致堆栈溢出的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:SetTimeout导致堆栈溢出
基础教程推荐
猜你喜欢
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 动态更新多个选择框 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01