jQuery AJAX 队列优先级
Posted
技术标签:
【中文标题】jQuery AJAX 队列优先级【英文标题】:jQuery AJAX Queue Priority 【发布时间】:2012-02-22 10:32:41 【问题描述】:我有一个“补充”数据的大表,这些数据是在页面加载时从大量 ajax 请求中填充的。这些请求可能需要 1 分钟以上才能完成。在加载此数据时,用户可以在页面上执行调用其他 ajax 请求的操作。我遇到的问题是调用附加 ajax 请求的用户操作在队列中的所有其他 ajax 请求都已处理后才完成。这是由于使用了所有同域浏览器连接和 jQuery ajax 队列。
不幸的是,更改子域不是一种选择,也不是为了不使用所有相同的域连接而设置同步队列。
我想要的是一个“优先级”请求的选项,将用户请求放在首位。
有没有一种简单的方法可以用 jQuery 的 ajax 队列来完成这个任务?
编辑:
如果没有办法管理请求队列(因为它开始出现),是否可以使用 $.ajax 函数回调 beforeSend 来“推迟”排队的请求?
【问题讨论】:
我认为您遇到的限制是浏览器限制,除了 jquery 为您发起请求之外,与 jquery 无关。您是否可以整合其他一些 ajax 请求,以将需要执行的请求数量减少到更少? 最后我创建了一个全局对象来维护对所有 ajax 请求的引用。然后我重写了我的 ajax 请求,以便在我想取消并重新启动它们时更加宽容。这意味着如果交易 100% 完成,则跟踪元素本身。最后,在我的用户发起的操作中,我停止了所有当前和未决的 ajax 请求,并发出由用户启动的请求。然后我重新启动所有其他 ajax 请求。因为我已经跟踪了之前请求的完成状态,所以我可以跳过已经完成的请求。 【参考方案1】:一旦请求被分派,就由服务器来处理它。由于它是异步的,因此您无法控制何时接收响应以及以何种顺序接收响应。服务器甚至也没有真正“意识到”同一会话的其他请求正在等待处理...您可能会更改此设置,但它需要在 Web 服务器如何管理请求方面进行大量工作。
您真正能做的唯一事情是在所有数据加载之前阻止用户进行交互。
【讨论】:
这很有道理,我想我认为是 jQuery 处理请求,而不是浏览器。 jQuery 只是浏览器内置 AJAX 处理程序的包装器。以上是关于jQuery AJAX 队列优先级的主要内容,如果未能解决你的问题,请参考以下文章