获取多个接口的数据并进行处理,使用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)
          })
      },
相关推荐
子兮曰7 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭7 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路9 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒11 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
lemon_yyds11 小时前
《vue 2 升级vue3 父组件 子组件 传值: value 和 v-model
vue.js
Kagol12 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉12 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau12 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生12 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼12 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范