迭代集合并对每个元素进行单独的 Ajax 调用时,必须控制顺序以防止服务器过载和浏览器冻结。虽然可以使用自定义迭代器,但还有更优雅的解决方案可用。
在 jQuery 1.5 及更高版本中,$.ajaxQueue() 插件利用 $ .Deferred、$.queue() 和 $.ajax() 用于管理请求排序并提供在请求完成时解析的承诺。
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,动画队列可用于创建自定义“队列”。您还可以创建自己的 $.ajaxQueue() 插件,该插件使用 jQuery 的“fx”队列自动启动队列中的第一个请求(如果该请求尚未运行)。
var oldComplete = ajaxOpts.complete; ajaxQueue.queue(function(next) { ajaxOpts.complete = function() { if (oldComplete) oldComplete.apply(this, arguments); next(); }; $.ajax(ajaxOpts); });
};
})(jQuery);
url: '/echo/html/', data: {html : "[" idx "] " $(this).html()}, type: 'POST', success: function(data) { $("#output").append($("<li>", { html: data })); }
});
});
这可确保每个 Ajax 请求按顺序执行,从而可以优雅地处理服务器负载并保持浏览器响应能力.
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3