for循环中的jQuery延迟队列

时间:2015-05-13 13:06:24

标签: javascript jquery ajax deferred

我有以下功能:

function getData(a,url) {
        var deferreds = [];
        var i = 1;
        for (i = 1; i <= a.length; i++) {
            var count = i;
            var back = a[i]['link'];
            var path = "http://example.com";
            deferreds.push(
            $.ajax({
                url:path,
                data:{back:back,link:url},
                type:"POST",
                async: true,
                delay: count
            }).done(function(data) {
                //success function here
            }));
        }


        return deferreds;
    }

我的问题是如何使这个脚本运行一个队列,例如我有2000个请求,如何将它们逐个放入100个队列中?

1 个答案:

答案 0 :(得分:1)

也许这样(当然是简化)

var completed = 0;
var limit_simultaneous = 100;
var total_requests = 2134 // Assign your var

function send_block() {
    for (i = 0; i < limit_simultaneous; i++) {
        $.ajax({
            url:path,
            data:{back:back,link:url},
            type:"POST",
            async: true,
        }).done(function(data) {
           completed++;
           send_next_block();
           //success function here
        }));
    }
}

function send_next_block() 
{
    if (completed == limit_simultaneous && total_requests > 0) {
        total_requests = total_requests - completed;
        if (total_requests < limit_simultaneous) {
            limit_simultaneous = total_requests;
        }
        completed = 0;
        // Fire again
        send_block(); // Send another 100
    }
}

我希望它有所帮助。

编辑编辑以考虑总请求数。也许不是一个有效的代码,但这是一个想法。