js 实现 ajax 并发请求

  1. Promise.all 并发请求(全部完成后处理)
javascript 复制代码
// 使用 fetch 作为示例
function getData(url) {
  return fetch(url).then(res => res.json());
}

Promise.all([
  getData('/api/user'),
  getData('/api/order'),
  getData('/api/cart')
])
.then(([user, order, cart]) => {
  console.log('用户数据:', user);
  console.log('订单数据:', order);
  console.log('购物车数据:', cart);
})
.catch(err => {
  console.error('其中一个请求失败:', err);
});

特点:

  • 所有请求是同时发出的
  • 只有全部成功才进入 .then,有一个失败就进入 .catch
  1. Promise.allSettled(不管成败都处理)
javascript 复制代码
Promise.allSettled([
  fetch('/api/user').then(res => res.json()),
  fetch('/api/order').then(res => res.json()),
  fetch('/api/cart').then(res => res.json())
])
.then(results => {
  results.forEach((result, index) => {
    if (result.status === 'fulfilled') {
      console.log(`第${index+1}个成功:`, result.value);
    } else {
      console.error(`第${index+1}个失败:`, result.reason);
    }
  });
});

特点:

  • 不会因为某个失败而中断
  • 每个请求的状态都会返回
  1. 限制并发数(比如同时只能跑 2 个)
javascript 复制代码
// 并发控制工具
async function limitConcurrency(urls, limit) {
  const results = [];
  const queue = [...urls];

  async function worker() {
    while (queue.length) {
      const url = queue.shift();
      try {
        const res = await fetch(url).then(r => r.json());
        results.push(res);
      } catch (err) {
        results.push(err);
      }
    }
  }

  const workers = Array.from({ length: limit }, worker);
  await Promise.all(workers);
  return results;
}

// 用法
limitConcurrency(['/api/1', '/api/2', '/api/3', '/api/4'], 2)
  .then(res => console.log('结果:', res));

特点:

  • 适合需要防止高并发压垮服务器的场景
  • 一批批并发执行
相关推荐
持梦远方2 分钟前
持梦行文本编辑器(cmyfEdit):架构设计与十大核心功能实现详解
开发语言·数据结构·c++·算法·microsoft·visual studio
HeDongDong-4 分钟前
Kotlin 协程(Coroutines)详解
android·开发语言·kotlin
阿里嘎多学长5 分钟前
2025-12-29 GitHub 热点项目精选
开发语言·程序员·github·代码托管
菩提小狗6 分钟前
第3天:基础入门-抓包&封包&协议&APP&小程序&PC应用&WEB应用|小迪安全笔记|网络安全|
前端·安全·小程序
AmsWait6 分钟前
微信H5订阅消息接入实战:样式错乱、返回值解析报错?避坑指南来了
javascript·微信
鹿角片ljp7 分钟前
深入理解Java集合框架:核心接口与实现解析
java·开发语言·windows
中屹指纹浏览器8 分钟前
2025边缘计算与本地指纹生成技术:浏览器指纹安全与抗检测方案解析
经验分享·笔记
不爱吃糖的程序媛9 分钟前
在鸿蒙PC上体验JavaScript应用开发:系统信息查看工具
javascript·华为·harmonyos
雨飞飞雨9 分钟前
深度学习响应式系统
前端·vue.js·前端框架
大布布将军13 分钟前
⚡后端安全基石:JWT 原理与身份验证实战
前端·javascript·学习·程序人生·安全·node.js·aigc