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

相关文章

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Node.js net模块的使用示例

《Node.jsnet模块的使用示例》本文主要介绍了Node.jsnet模块的使用示例,net模块支持TCP通信,处理TCP连接和数据传输,具有一定的参考价值,感兴趣的可以了解一下... 目录简介引入 net 模块核心概念TCP (传输控制协议)Socket服务器TCP 服务器创建基本服务器服务器配置选项服

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点: