jQuery中ajax可以用async:false关闭异步请求,但是在AppCan中,因为自行封装了appcan.js,所以没有办法关闭异步(希望以后能改进),直接导致数据提交顺序出错,例如:
for(var i2=0;i2<apply.length;i2++)
{var passurl = baseUrl + "meet/isFrozen";
var paramJSon = {
'meetingRoomId' : apply[i2],
'startTime':Zepto('#startTimeHi').val(),
'endTime':Zepto('#endTimeHi').val()
};
var testFrozen = new Array();
appcan.request.ajax({
type: 'POST',
url: passurl,
data: paramJSon,
contentType: 'application/json',
dataType:'json',
success:function(data, status, xhr)
{
testFrozen.push(data.isFrozen);
setLocVal('testFrozen',JSON.stringify(testFrozen));
transfer();
alert(11);
},
});
}
其执行顺序为:先把所有for循环执行完,但是不执行ajax请求,for循环完毕之后再依次将ajax请求执行完,但此时 apply[i2]已经固定为一个值,所以循环就没有起到想要的效果,为避免如此,将此方法进行改造,改为:
function XXX(i)
{
if(i<apply.length)
{
var passurl = baseUrl + "meet/isFrozen";
var paramJSon = {
'meetingRoomId' : apply[i2],
'startTime':Zepto('#startTimeHi').val(),
'endTime':Zepto('#endTimeHi').val()
};
var testFrozen = new Array();
appcan.request.ajax({
type: 'POST',
url: passurl,
data: paramJSon,
contentType: 'application/json',
dataType:'json',
success:function(data, status, xhr)
{
testFrozen.push(data.isFrozen);
setLocVal('testFrozen',JSON.stringify(testFrozen));
transfer();
i++;
XXX(i);
},
});
}
}
这样一来即是按照顺序执行。。