【ES6】一个页面上需要等两个或多个ajax的数据请求成功以后才正常显示(使用Promise.all和Promise.race)

【ES6】一个页面上需要等两个或多个ajax的数据请求成功以后才正常显示(使用Promise.all和Promise.race)

Pomise

Pomise.all

  • Promise.all将多个Promise实例聚合成一个新的Promise实例。请求成功的时候返回的是一个结果数组,而失败的时候则返回最先被reject失败的值(即如果有一个Pomise失败,则整个Pomise都返回失败)。
  • Promise.all获得的成功结果数组里的数据顺序和Promise.all接收到的数组顺序是一致的,即使Promise1的结果获取的比Promise2要晚。

具体代码如下

javascript 复制代码
<template>
  <div id="app"></div>
</template>
<script>
import { getuser, getlist, getdetail } from "@/api/api";
export default {
  name: "App",
  data() {
    return {};
  },
  mounted() {
    this.getData();
  },
  methods: {
    //获取后端数据
    async getData() {
      let Promise1 = await getuser(); //调用成功
      let Promise2 = await getlist(); //调用成功
      let Promise3 = await getdetail(); //调用失败
      let Promise4 = await getdetail(); //调用失败
      Promise.all([Promise1, Promise2])
        .then((result) => {
          console.log(result); //[[用户信息], [用户列表]]
        })
        .catch((error) => console.log(`Error in promises ${error}`));

      Promise.all([Promise1, Promise2, Promise3, Promise4])
        .then((result) => {
          console.log(result); //调用失败。返回Promise3错误信息
        })
        .catch((error) => console.log(`Error in promises ${error}`));
    },
  },
};
</script>

Promise.race

  • Promise.race([Promise1, Promise2, Promise3])里面哪个结果返回得的快,就返回那个结果,不管结果本身是成功状态还是失败状态。
相关推荐
3秒一个大17 小时前
Cookie/Session vs JWT 双 Token:登录认证方案的演进与对比
前端·安全·ajax
.豆鲨包17 小时前
【Android】OkHttp的使用及封装
android·java·okhttp
华科易迅18 小时前
Vue通过Ajax获取后台路由信息
vue.js·ajax·okhttp
用户8113581881202 天前
【AJAX-Day2】Promise与回调地狱
前端·ajax
studyForMokey2 天前
【Android面试】OkHttp & Retrofit 专题
android·okhttp·面试
fLDiSQV1W3 天前
springMVC-HTTP消息转换器与文件上传、下载、异常处理
网络协议·http·okhttp
酉鬼女又兒5 天前
零基础快速入门前端ES6 核心特性详解与蓝桥杯 Web 考点实践(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·职场和发展·蓝桥杯·es6·css3·html5
酉鬼女又兒5 天前
零基础快速入门前端ES6 核心特性详解:Set 数据结构与对象增强写法(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·es6
酉鬼女又兒5 天前
零基础快速入门前端蓝桥杯Web考点深度解析:var、let、const与事件绑定实战(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·es6·html5
Ttang237 天前
Java爬虫:Jsoup+OkHttp实战指南
java·爬虫·okhttp