码迷,mamicode.com
首页 > Web开发 > 详细

Ajax顺序执行

时间:2017-12-25 20:55:04      阅读:194      评论:0      收藏:0      [点我收藏+]

标签:json   gpo   代码   一个   结果   family   无效   url   连接   

循环中的Ajax

在前后端分离的项目中,Ajax是连接前后端的枢纽。

需求:有一个需要循环发起n次的请求,但是n次循环传参不同,我并不知道n是多少,并且要求能够保证返回顺序。JSONP用同步锁无效

示例一代码:

for(var i = 0;i<5;i++){
    $.ajax({
        url : ‘‘,
        data : {},
        type:‘GET‘,
        dataType : ‘jsonp‘,
        success: function(res){
            console.log(‘ok‘);
        },
        error : function () {
            console.log(i);
        }
    });
}

这个时候由于url为空,走error方法,我们想要输出12345,但事实控制台输出了55

因为ajax是异步请求,for循环会瞬间执行完,此时ajax还没有正确的返回数据。

实例二代码:

for(var i = 0;i<5;i++){
    (function (i) {
        $.ajax({
            url : ‘‘,
            data : {},
            type:‘GET‘,
            dataType : ‘jsonp‘,
            success: function(res){
                console.log(‘ok‘);
            },
            error : function () {
                console.log(i);
            }
        })
    })(i)
}

想利用闭包的方式传值,这时候输出结果012345不定排序,并不是按照我想要的顺序返回,因为我们不能确定哪个AJAX请求是先返回的。

示例三代码:

var currentIndex = 0;
function a(){
 if(currentIndex >= 5){
     return;
 }
 $.ajax({
     url : ‘‘,
     data : {},
     type:‘GET‘,
     dataType : ‘jsonp‘,
     success: function(res){
         alert(‘ok‘);
     },
     error : function () {
         currentIndex++;
         console.log(currentIndex);
         a();
     }
 });
}
a();

由于我们并不知道会有多少请求发送,所以以递归的形式循环,既能循环najax请求,又能保证数据返回的顺序。

 

Ajax顺序执行

标签:json   gpo   代码   一个   结果   family   无效   url   连接   

原文地址:https://www.cnblogs.com/yuqing-o605/p/8110983.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!