论坛首页 Web前端技术论坛

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

浏览 8347 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2015-01-27  

在项目前台中,很多情况会使用到对一个集合进行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
   发表时间:2015-01-28  
async : false,//是否为同步------------>应该是否为异步
1 请登录后投票
   发表时间:2015-01-30  
正确的做法是Promise模型.

0 请登录后投票
   发表时间:2015-01-31  
看来楼主没接触过jquery的deffered 对象吧?promise估计也不知道....
0 请登录后投票
   发表时间:2015-02-09  
bewithme 写道
async : false,//是否为同步------------>应该是否为异步


恩,写错了,呵呵。
0 请登录后投票
   发表时间:2015-02-09  
james_lover 写道
正确的做法是Promise模型.


又学习了,呵呵。
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics