获取多个接口的数据并进行处理,使用Promise.all来等待所有接口请求完成

Promise.all (等待机制) 方法

它调用了多个函数,这些函数返回了Promise对象,每个Promise对象代表了一个异步操作。

然后,使用Promise.all将这多个Promise对象包装成一个新的Promise对象,它会等待所有的Promise都完成(或者其中一个被拒绝)。

当所有的Promise都成功完成时,Promise.all的.then方法会被触发,传入一个数组参数,包含了每个Promise成功时的结果。

接下来,你可以在.then方法的回调函数中使用这些数据,进行后续的操作或处理。这段代码的目的是等待这几个异步操作都完成后再继续执行后续代码,以确保所有数据都可以同时渲染。

Promise.race (赛跑机制)

1、business.js接口文件内定义接口

复制代码
const getTotalUserone = (params) =>
  getAction('/admin/consumer/totalUserone', params)
const getTotalUsertwo = (params) =>
  getAction('/admin/consumer/totalUsertwo', params)
const getTotalUserthree = (params) =>
  getAction('/admin/consumer/totalUserthree', params)
const getTotalUserfour = (params) =>
  getAction('/admin/consumer/totalUserfour', params)
const getTotalUserfive = (params) =>
  getAction('/admin/consumer/totalUserfive', params)

2、页面中导入接口

复制代码
  import {
    getTotalUserone,
    getTotalUsertwo,
    getTotalUserthree,
    getTotalUserfour,
    getTotalUserfive,
    areaTypeLists,
  } from '@/api/business'

3、调用初始化函数

复制代码
    created() {
      this.initData()
    },

4、调用接口,获取数据

复制代码
      initData() {
        // 定义多个接口请求的Promise
        const areaTypeData = areaTypeLists()
        const getline2Data = getTotalUserone()
        const getbar1Data = getTotalUsertwo()
        const getbar2Data = getTotalUserthree()
        const getpie1Data = getTotalUserfour()
        const getpie2Data = getTotalUserfive()
        // 使用Promise.all来等待所有接口请求完成
        Promise.all([
          areaTypeData,
          getline2Data,
          getbar1Data,
          getbar2Data,
          getpie1Data,
          getpie2Data,
        ])
          .then(
            ([
              areaTypeData,
              getline2Data,
              getbar1Data,
              getbar2Data,
              getpie1Data,
              getpie2Data,
            ]) => {
               // 将这些数据分别赋值给相应的变量或对象属性
               // 逻辑操作,筛选过滤数据等
            }
          )
          .catch((error) => {
            console.error(error)
          })
      },
相关推荐
超级码力6668 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
ZC跨境爬虫8 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人8 小时前
HTML 字符引用完全指南
开发语言·前端·html
幼儿园技术家9 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
图扑可视化9 小时前
基于图扑软件 HT 2.5D 组态可视化技术的场景实现
信息可视化·数字孪生·组态软件
前端摸鱼匠10 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker11 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
Elastic 中国社区官方博客11 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
donecoding12 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马12 小时前
Raku正则匹配与数据批量处理实操案例
前端