【问题标题】:How to trigger ajax requests queue start?如何触发ajax请求队列启动?
【发布时间】:2012-03-06 17:54:26
【问题描述】:

我按照answer 中给出的方法创建 ajax 请求队列。但是我的队列是在线创建的(取决于用户操作),所以我的功能如下:

sendMessage = function(fieldName, oldValue, newValue) {
  $(document).queue("ajaxRequests", function() {
    // ...
    $.ajax({
      // ...
      success: function(data) {
        $(document).dequeue("ajaxRequests");
      }
    });
  });
  $(document).dequeue("ajaxRequests");
};

所以,我会多次调用这个sendMessage 函数。因为我在这个函数的末尾有$(document).dequeue("ajaxRequests");,所以看起来它不能正常工作——ajax 会启动几次。

那么,如何第一次正确触发函数呢?也许我应该检查队列长度?或者,我应该使用fully manual queue吗?

【问题讨论】:

  • 我已经放弃了快速并发请求的 que 模型。选择时间戳和唯一的客户端 ID,允许服务器整理出实际更新。

标签: javascript jquery ajax queue


【解决方案1】:

我会使用延迟对象http://api.jquery.com/category/deferred-object/

您创建一个已解析的延迟对象作为队列并随意管道您的请求。例如

var mid=0; var queue=$.Deferred(); queue.resolve();

function sendMessage(msgId) {
        return $.ajax({
            type: "GET",
            url: "/echo/json/",
            data: {delay: 1},
            dataType: "JSON",
            success: function(){
                console.log("Success for " + msgId+ "");
            }
        });
}

function queueMessage() {
    var m=++mid;
    console.log("Queueing "+m)

    queue=queue.pipe( function() {
        return sendMessage(m);
    });
}

queueMessage();
queueMessage();

一个小提琴http://jsfiddle.net/j6CKj/

【讨论】:

  • 谢谢,nikoshr。它没有回答我的问题,但这是一个很好的解决方案,所以我接受它;)
猜你喜欢
  • 1970-01-01
  • 2011-06-30
  • 1970-01-01
  • 2017-08-23
  • 2011-07-16
  • 1970-01-01
  • 2019-07-30
  • 2020-03-03
  • 1970-01-01
相关资源
最近更新 更多