首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多个XHR请求进度跟踪

多个XHR请求进度跟踪
EN

Stack Overflow用户
提问于 2014-11-28 02:34:28
回答 1查看 1.1K关注 0票数 0

目前正在进行5次请求。如果采用event.loaded,则每次显示来自随机5个进度事件的替换值。我们如何针对每个xhr请求?

代码语言:javascript
复制
var xhr = [];

for (i = 0; i < 5; i++) {
  (function(i) {
    var start = new Date().getTime();
    xhr[i] = new XMLHttpRequest();
    url = "/" + "?n=" + Math.random();
    xhr[i].open("POST", url, true);
    xhr[i].setRequestHeader("Content-Type", "text/plain;charset=UTF-8");
    xhr[i].upload.addEventListener("progress", progressHandler, false);

    function progressHandler(event) {
      end = new Date().getTime();
      time = (end - start) / 1000;
      var duration = time;
      var bytes = event.loaded;
    }
  };
  xhr[i].send(UploadData);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-11-28 04:01:58

这是因为对所有5个进程都使用相同的处理程序,因此每个进程都需要单独的处理程序。然后可以使用共享范围计算总体进度:

代码语言:javascript
复制
var xhr = [];
var progress = [];


for (i = 0; i < 5; i++) {
  (function(i) {
    var start = new Date().getTime();
    xhr[i] = new XMLHttpRequest();
    url = "/" + "?n=" + Math.random();
    xhr[i].open("POST", url, true);
    xhr[i].setRequestHeader("Content-Type", "text/plain;charset=UTF-8");
    xhr[i].upload.addEventListener("progress", createProgressHandler(start, i), false);
    xhr[i].send(UploadData);
    // Initialize progress:
    progress[i] = { bytes: 0 };
};

function createProgressHandler(start, i) {
    return function (event) {
      end = new Date().getTime();
      time = (end - start) / 1000;
      var duration = time;
      var bytes = event.loaded;

      progress[i].bytes = bytes;

      console.log('Event from upload #' + i + ', bytes loaded: ' + bytes);
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27181121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档