首页 > web前端 > js教程 > 正文

如何对 Ajax 请求进行排序以实现最佳控制?

Mary-Kate Olsen
发布: 2024-10-20 12:32:02
原创
542 人浏览过

How to Sequence Ajax Requests for Optimal Control?

对 Ajax 请求进行排序

迭代集合并对每个元素进行单独的 Ajax 调用时,必须控制顺序防止服务器过载和浏览器冻结。虽然可以使用自定义迭代器,但还有更优雅的解决方案可用。

jQuery 1.5

在 jQuery 1.5 及更高版本中,$.ajaxQueue() 插件利用 $.Deferred、$.queue() 和 $.ajax() 来管理请求排序并提供在请求完成时解析的承诺。

实现:

<br>(function($) {</p>
<p>var ajaxQueue = $({});</p>
<p>$.ajaxQueue = function( ajaxOpts ) {</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var jqXHR,
    dfd = $.Deferred(),
    promise = dfd.promise();

ajaxQueue.queue( doRequest );

promise.abort = function( statusText ) {
  if ( jqXHR ) {
    return jqXHR.abort( statusText );
  }
  var queue = ajaxQueue.queue(),
      index = $.inArray( doRequest, queue );
  if ( index > -1 ) {
    queue.splice( index, 1 );
  }
  dfd.rejectWith( ajaxOpts.context || ajaxOpts,
    [ promise, statusText, "" ] );
  return promise;
};

function doRequest( next ) {
  jqXHR = $.ajax( ajaxOpts )
    .done( dfd.resolve )
    .fail( dfd.reject )
    .then( next, next );
}

return promise;
登录后复制

};

})(jQuery);

jQuery 1.4

对于 jQuery 1.4,动画队列可用于创建自定义“队列”。您还可以创建自己的 $.ajaxQueue() 插件,该插件使用 jQuery 的“fx”队列自动启动队列中的第一个请求(如果尚未运行)。

实现:

<br>(function($) {<br> var ajaxQueue = $({});</p>
<p>$.ajaxQueue = function(ajaxOpts) {</p> <pre class="brush:php;toolbar:false">var oldComplete = ajaxOpts.complete;

ajaxQueue.queue(function(next) {
  ajaxOpts.complete = function() {
    if (oldComplete) oldComplete.apply(this, arguments);
    next();
  };
  $.ajax(ajaxOpts);
});
登录后复制

};

})(jQuery);

示例:

<br>$("#items li").each(function(idx) {<br> $.ajaxQueue({</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">url: '/echo/html/',
data: {html : "["+idx+"] "+$(this).html()},
type: 'POST',
success: function(data) {
  $("#output").append($("<li>", { html: data }));
}
登录后复制

});
});

这可确保每个 Ajax 请求按顺序执行,从而可以优雅地处理服务器负载并保持浏览器响应能力。

以上是如何对 Ajax 请求进行排序以实现最佳控制?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
上一篇:是什么导致 Google Chrome 的 Console.log() 中数组和对象的行为不一致? 下一篇:ES6 类真的只是 JavaScript 原型模式的更漂亮版本吗?
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
相关专题
更多>
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!