普通网友 2017-02-08 17:35
浏览 74

AJAX请求池

I have array of FormData objects and I want to post them to same URL. I want to make fixed number of AJAX requests at a time, for that I want to create pool of xhr objects. How to do that?

  • 写回答

1条回答 默认 最新

  • weixin_33717298 2017-02-08 18:11
    关注

    You can use Array.prototype.splice(), Promise.all(), fetch() to perform N requests at a time.

    let data = [FormData, FormData, ..];
    
    let N = 5;
    
    let pool = data.splice(0, N);
    
    let processData = requests => 
      Promise.all(
        requests.map(fd =>
          fetch("/path/to/server", {
            method: "POST",
            body: fd
          })
          .then(response => response.ok)
        )
      )
      .then(responses => responses.every(result => result))
      .then(result => {
        if (result) {
          if (data.length) {
            pool = data.splice(0, N);
            return true
          }
        }
        return "complete"
      });    
    
    let fn = next => next === true ? processData(pool).then(fn) : next;
    
    processData(pool)
    .then(fn)
    .then(complete => console.log(complete))
    .catch(err => console.log(err));
    

    jsfiddle https://jsfiddle.net/ce1kzu52/5/

    You can also process the array without scheduling the function processData to be called again if any elements are remaining in array.

    评论

报告相同问题?

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀