我对 javascript 的理解一直是代码是按顺序执行的,所以下一行要等到上一行执行后才会执行。
我有类似以下的东西,我试图用它来尝试一次保存一系列问题。
for(var i = 1; i <= assessment_question_count; i++)
{
if(valid)
{
var sort = i;
$.ajax(
{
type: "POST",
url: '/assessmentquestion/create',
data: 'assessment_id=' + assessment[1] + '&question_text=' + $('#assessment_question_text_' + sort).val() + '&assessment_question_type_id=' +
$('assessment_question_type_' + sort).val() + '&sort_order=' + i,
success: function (str)
{
var result = str.split('|');
if (result[0] == 'success')
{
var message = '<br />Question saved ';
update_display_message(message);
}
else if(result[0] == 'fail')
{
valid = false;
var message = '<br />Error saving question ';
}
else
{
valid = false;
var message = '<br />Error saving question ';
}
}
});
}
}
我遇到的问题是它似乎在进行 ajax 调用后立即进入下一个循环,而不是等待它完成。有没有办法修改它,所以在之前的更新之前它不会尝试下一个问题?
编辑:我在想也许把它放在一个递归方法中,它会一直调用自己直到它完成。