js for循环中使用$.post方法

在项目前台中,很多情况会使用到对一个集合进行for循环,然后每一次循环,都要重新请求一次后台,

此时有可能会碰到一种问题,就是for 循环的结果可能少了或者在for循环请求的结果不是正确的结果。这种情况主要原因如下:

该技术博客属于原创文章 ,转载请注明出处:http://www.pm-road.com/index.php/2015/01/12/337/

$.post()属于异步请求,所以在执行for 循环的时候,JS 发送了一个异步的post 请求,但是在该请求还没有返回结果的同时 ,JS继续执行了第二次for 循环,依次类推,有可能js把for 循环都执行完了,第一次的post 请求还没有结束,此时就可能出现种种问题;

 

而解决该问题的办法 就是把post 请求换成同步请求,当post 结束之后,才会进行下一次循环;

但问题又来了,$.post()的格式 为$.post(url,para,function,type)    这四个参数依次为请求url,请求参数,请求回调函数,请求类型,并没有一个参数是设置异步还是同步的,所以,此时就应该换一种请求方 法,$.ajax(); 参数如下:

$.ajax({
type: "POST",
url: url,
 async : false,//是否为同步
data: data,
success: success,
dataType: dataType
});
所以在for循环中使用请求方法,最好使用$.ajax ,而非使用post

你可能感兴趣的:(js,javascript)