I have an procedure that runs throught 5 consecutive steps, and in my page, I'm calling an ajax method for each of them.
The idea is to run the first, if all is ok the second, and so on.
My code is:
$("#foo").click(function(){
$.ajax({
url: 'ajax.php',
async: false,
data: {
step: 1
},
dataType: 'json',
type: 'GET',
success: walk_through(data)
});
});
function walk_through(data)
{
if(data.status == 'ok')
{
if(data.next_step == 'end')
{
// All steps pleted
}
else
{
// Current step pleted, run next one
$.ajax({
url: 'ajax.php',
async: false,
data: {
step: data.next_step
},
dataType: 'json',
type: 'GET',
success: walk_through(data)
});
}
}
else
{
alert("Error.");
console.log(data);
}
}
Im getting "too much recursion" error, even if my ajax calls are set as syncronous.. why?
I have an procedure that runs throught 5 consecutive steps, and in my page, I'm calling an ajax method for each of them.
The idea is to run the first, if all is ok the second, and so on.
My code is:
$("#foo").click(function(){
$.ajax({
url: 'ajax.php',
async: false,
data: {
step: 1
},
dataType: 'json',
type: 'GET',
success: walk_through(data)
});
});
function walk_through(data)
{
if(data.status == 'ok')
{
if(data.next_step == 'end')
{
// All steps pleted
}
else
{
// Current step pleted, run next one
$.ajax({
url: 'ajax.php',
async: false,
data: {
step: data.next_step
},
dataType: 'json',
type: 'GET',
success: walk_through(data)
});
}
}
else
{
alert("Error.");
console.log(data);
}
}
Im getting "too much recursion" error, even if my ajax calls are set as syncronous.. why?
Share Improve this question asked Jun 13, 2011 at 12:38 StraeStrae 19.5k29 gold badges96 silver badges133 bronze badges 3- Does the code work despite the error, or is it failing? Do you really want the requests to be synchronous? It wouldn't be recursive at all if they were asynchronous. – Pointy Commented Jun 13, 2011 at 12:41
- you obviously do not ever get next_step == 'end' check what is the response – venimus Commented Jun 13, 2011 at 12:44
- @Pointy: no, I dont need the requests to be syncronous, but i thought the problem was that – Strae Commented Jun 13, 2011 at 12:57
3 Answers
Reset to default 9Change
success: walk_through(data)
To
success: walk_through
You want the function walk_through
to be the success handler, but you don't want to call the function immediately.
Your JavaScript is wrong on your AJAX call:
$.ajax({
url: 'ajax.php',
async: false,
data: {
step: data.next_step
},
dataType: 'json',
type: 'GET',
success: walk_through //You had walk_through(data), which makes a function call, rather than a reference to a function.
});
Your walk_through function is calling itself everytime it is succesful.