Javascript setTimeout导致堆栈溢出
我有以下代码。它会导致堆栈溢出异常 知道我做错了什么吗Javascript setTimeout导致堆栈溢出,javascript,settimeout,Javascript,Settimeout,我有以下代码。它会导致堆栈溢出异常 知道我做错了什么吗 var myApi = { rawData: null, initData: function() { // ajax call to get data and populate myApi.rawData, max 10 seconds }, waitForRawData: function(callback) { if
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);
当您将其作为函数传递时,超时可以在您告诉它时调用它—在您的情况下,一秒钟后。如果不使用包装函数,现在就调用相同的代码