weixin_33695450 2019-06-30 20:10 采纳率: 0%
浏览 59

Ajax循环等待完成

I have an ajax call inside a loop:

$.each(chunkedImages, function(index, image) {
    $.ajax({
        type: 'POST',
        url: url,
        data: {images: image, key: key},
    }).success(function( data ) {
        countConvertedImages += data;

        if( index === chunkedImages.length-1 ) {
            console.log( countConvertedImages );
        }
    });

});

My problem is that the "countConvertedImages" variable is not up to date. There is not the correct value inside, for some reason. I think it has to do with the order of the ajax calls because they might not be finished.

How can I output something after all ajax calls have finished?

  • 写回答

2条回答 默认 最新

  • YaoRaoLov 2019-06-30 20:55
    关注

    Use $.when as mention below

     $.when(
                    $.each(chunkedImages, function (index, image) {
                        $.ajax({
                            type: 'POST',
                            url: url,
                            data: { images: image, key: key },
                            success: function (data) {
                                countConvertedImages += data;
                                if (index === chunkedImages.length - 1) {
                                    console.log(countConvertedImages);
                                }
                            }
                        })
                    })
                ).done(function () {
                });
    
    评论

报告相同问题?