jquery 循环调用ajax发送请求

jquery 循环调用ajax发送请求,如果用

for(){

$.ajax();

}

这种方式会出现问题:for完了,但是ajax并没有请求完成,也容易出现对象重用,等错误

注,就算使用ajax同步,async:false,也会出现获取成功返回值出错!


解决方案:递归调用

var times= xmlStrArr.length;
//递归发送请求
CloudiaTransfer_func(times,xmlStrArr);//xmlStrArr是我遍历的参数数组

function CloudiaTransfer_func(times,xmlStrArr){
    if(times <= 0){
        return;
    }
    (function($){
        temp = times-1;
        $.ajax({
            //cache: true,
            type: "get",
            url:"http://127.0.0.1:6789/?Request=CloudiaTransfer",
            data:xmlStrArr[temp],
            cache:false,
            async:false,
            dataType:"jsonp",
            jsonp:"success_jsonpCallback",//服务端用于接收callback调用的function名的参数
            jsonpCallback:"success_jsonpCallback",//callback的function名称
            error: function(request) {;
                //console.log(request);
                alert('error:'+temp)
            },
            success: function(data) {
                //$("#"+ContentID).html('上传中');
                $(".locState span").html('上传中');
                var Result = data[0].Result;
                alert('ok:'+temp)
                times --;
                CloudiaTransfer_func(times,xmlStrArr); //递归调用
            }
        });
    })(jQuery);

}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值