码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vue axios封装并发请求


    场景:有时候进入某些页面时会同时请求很多个业务接口, 如果一个一个的发送请求,会产生很多冗余,所以封装了一个方法(参考渡一教育袁老师课程)。

    此方法会根据请求顺序,返回一个返回结果数组,异常的结果会返回null

    可以优化的地方,请求方式,以及传参。我这里是根据自身业务封装的

    1. import request from "./request";
    2. /**
    3. * maxNum:最大请求数
    4. * @param {string[]} urls 待请求的url数组
    5. * @param {number} maxNum 最大并发数
    6. */
    7. export function concurRequest(urls, maxNum) {
    8. return new Promise((resolve) => {
    9. if (urls.length === 0) {
    10. resolve([]);
    11. }
    12. let index = 0; // 下一次请求对应的url地址下标
    13. let count = 0; // 请求完成的数量
    14. const result = [];
    15. async function sendRequest() {
    16. const i = index;
    17. const url = urls[index];
    18. index++;
    19. try {
    20. const resp = await request.post(url);
    21. result[i] = resp;
    22. } catch (error) {
    23. result[i] = error;
    24. } finally {
    25. count++;
    26. if (count === urls.length) {
    27. resolve(result);
    28. }
    29. if (index < urls.length) {
    30. sendRequest();
    31. }
    32. }
    33. }
    34. for (let i = 0; i < Math.min(urls.length, maxNum); i++) {
    35. sendRequest();
    36. }
    37. });
    38. }

    使用

    1. async getPageData() {
    2. let proxyName = "api";
    3. let urls = [
    4. `${proxyName}/binhu/getComponentTypeStatistic`, // 设备部件
    5. `${proxyName}/binhu/getComponentStatusStatistic`, // 状态统计
    6. ];
    7. await concurRequest(urls, 5).then((res) => {
    8. let resultMap = res.map((item) => item.code === 200 && item.data);
    9. if (resultMap[0]) {
    10. let _componentsList = this.componentsList;
    11. resultMap[0].forEach((el) => {
    12. _componentsList.forEach((item) => {
    13. if (item.name.includes(el.name)) {
    14. item.queryKey = el.name;
    15. item.value = el.count;
    16. }
    17. });
    18. });
    19. this.componentsList = _componentsList;
    20. this.handleClickItem(
    21. 0,
    22. this.componentsList[0].type,
    23. this.componentsList[0].queryKey
    24. );
    25. }
    26. // 设备状态统计
    27. resultMap[1] && (this.allDevice = resultMap[1]);
    28. });
    29. },

  • 相关阅读:
    excel系列(二) - 利用 easypoi 快速实现 excel 文件导入导出
    计算机毕业设计ssm企业员工培训管理系统2q63c系统+程序+源码+lw+远程部署
    Vue 3 中的 ref 和 reactive 有什么区别?
    存储创新靠软件?
    python数据分析——数据可视化(图形绘制)
    【Linux:进程概念】
    ⑤、企业快速开发平台Spring Cloud之HTML <head>
    小龙虾算法优化极限学习机实现乳腺癌诊断,(COA-ELM)数据分类
    0基础学习VR全景平台篇第109篇:认识拼接软件PTGui Pro
    Java项目——博客系统(前后端交互)
  • 原文地址:https://blog.csdn.net/weixin_42704663/article/details/133864033
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号