js async 分批次请求

2024-04-03 10:28
文章标签 请求 js async 批次

本文主要是介绍js async 分批次请求,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:如果merchantNos的数量大于1000需要分批进行请求,如为5000条,则分五次请求,然后把请求的数据拼在一起,如何做到

const merchantNos = ["123","123","123","123","123","123"
]
export const queryOrgInfos = async (params) => {return new Promise((resolve) => {// 模拟异步请求延迟setTimeout(() => {const mockResponse = {code: 0,data: [{"poiName": "123餐厅","merchantNo": "1234","address": "钟楼","brandName": "123品牌",}],};resolve(mockResponse);}, 1000); // 延迟1秒以模拟异步请求});
};
const merchantDetails = await queryOrgInfos(merchantNos);
console.log(merchantDetails, 'merchantDetails')
const queryOrgInfos = async (params) => {return new Promise((resolve) => {// 模拟异步请求延迟setTimeout(() => {const mockResponse = {code: 0,data: [{"poiName": "123","merchantNo": "123","address": "钟楼","brandName": "123",}],};resolve(mockResponse);}, 1000); // 延迟1秒以模拟异步请求});
};
// 定义一个函数,用于分批处理请求,并合并结果
const batchQueryOrgInfos = async (merchantNos, batchSize) => {// 计算需要分多少批const batchCount = Math.ceil(merchantNos.length / batchSize);let allData = [];for (let i = 0; i < batchCount; i++) {// 计算每一批的开始和结束索引const start = i * batchSize;const end = Math.min(start + batchSize, merchantNos.length);// 获取当前批次的merchantNosconst currentBatch = merchantNos.slice(start, end);console.log(currentBatch, 'currentBatch')// 发起请求并获取结果const response = await queryOrgInfos(currentBatch);// 检查响应码是否为0(成功)if (response.code === 0) {// 将当前批次的数据添加到总数据中allData = allData.concat(response.data);} else {// 可以根据实际需求处理错误情况console.error('Error fetching data for batch:', i, 'Response:', response);}}return {code: 0,data: allData};
};// 假设我们有5000个merchantNos
const merchantNos = ["51550082","51550083","51550084","51550085","51550086"
]; // 5000个merchantNo的数组// 定义每批请求的大小
const batchSize = 3;// 使用分批处理函数获取所有的商户详情
const merchantDetails = await batchQueryOrgInfos(merchantNos, batchSize);
console.log(merchantDetails, 'merchantDetails');

这篇关于js async 分批次请求的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/872664

相关文章

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/