JS中使用Promise.all控制所有的异步请求都完成后,在执行后续逻辑
1 QueryOrderInfo(orderId).then((orderResult) => {
2 if (!orderResult.success) {
3 Xrm.Utility.alertDialog(`查询所选订单的信息及明细信息失败!【${orderResult.message}】`);
4 return
5 }
6 let shippingId = commonUtil.delBrackets(Xrm.Page.data.entity.getId())
7 let promiseArray = []
8 orderResult.details.forEach((p, idx) => {
9 promiseArray.push(CreateShippingOrderDetailPromise(p, orderResult.order, shippingId))
10 })
11 Promise.all(promiseArray).then((res) => {
12 console.log(res);
13 let failReqs = Object.entries(res).filter((a) => !(a[1].success))
14 if (failReqs.length) {
15 Xrm.Utility.alertDialog(failReqs.map(e => e[1].message).join('\n'))
16 }
17 window.top.location.reload()
18 })
19 }).catch((err) => { console.error(err) })
20
21
22 /**
23 * 根据整车订单id查询整车销售订单明细
24 * @param {any} orderId 整车订单数据id
25 */
26 function QueryOrderInfo(orderId) {
27 return new Promise((resolve, reject) => {
28 let queryPromises = [GetOrderInfo(orderId), GetOrderDetails(orderId)]
29 Promise.all(queryPromises).then((res) => {
30 let orderRes = res[0]
31 let detailRes = res[1]
32 resolve({
33 success: res.every(r => r.success),
34 message: (orderRes.success ? "" : `[${orderRes.message}]`) + (detailRes.success ? "" : `[${detailRes.message}]`),
35 order: orderRes.data,
36 details: detailRes.data
37 })
38 })
39 })
40 }
41 /**
42 * 通过销售订单ID查询销售订单的付款方式(new_paymentmethod)以及对应销售合同的合同号(new_sales_contract_number)
43 * @param {any} orderId
44 * @returns
45 */
46 function GetOrderInfo(orderId) {
47 return new Promise((resolve, reject) => {
48 let queryUrl = `/new_orders(${orderId})?$select=new_paymentmethod&$expand=new_sales_contractid($select=new_sales_contract_number)`
49 let result = { success: false, message: '未能正确查找', data: null }
50 commonUtil.queryWithUrl(queryUrl, function (res) {
51 if (!res) {
52 result.message = '查询销售订单信息异常,添加订舱信息反馈单明细失败!'
53 } else if (!res.success) {
54 result.message = res.message
55 } else if (res.data) {
56 result.success = true
57 result.data = {
58 new_paymentmethod: res.data["new_paymentmethod@OData.Community.Display.V1.FormattedValue"],
59 new_contractno: res.data.new_sales_contractid && res.data.new_sales_contractid.new_sales_contract_number
60 }
61 }
62 resolve(result)
63 }, false);
64 })
65 }
66
67 /**
68 * 根据销售订单ID查询相关的销售订单明细记录
69 * @param {any} orderId
70 * @returns
71 */
72 function GetOrderDetails(orderId) {
73 return new Promise((resolve, reject) => {
74 let selFields = 'new_count,new_name,new_order_detailid,new_expected_output_time,_new_product_fourthid_value,_new_way_of_packagingid_value'
75 let queryUrl = `/new_order_details?$select=${selFields}&$expand=new_way_of_packagingid($select=new_high,new_long,new_wide)&$filter=_new_order_value eq ${orderId}`
76 let result = { success: false, message: '未能正确查找', data: null }
77 commonUtil.queryWithUrl(queryUrl, function (obj) {
78 if (!obj) {
79 result.message = '查询销售订单明细异常,添加订舱信息反馈单明细失败!'
80 } else if (!obj.success) {
81 result.message = obj.message
82 } else if (obj.data && obj.data.length) {
83 result.success = true
84 result.data = obj.data
85 }
86 resolve(result)
87 }, false);
88 })
89 }
90
91
92 /**
93 * 根据销售订单明细创建反馈单明细记录
94 * @param {any} orderDetail 销售明细数据
95 */
96 function CreateShippingOrderDetailPromise(orderDetail, order,shippingId) {
97 return new Promise((resolve, reject) => {
98 //包装方式
99 var wayOfPackaging = orderDetail.new_way_of_packagingid
100 let shippingOrderDetail = {
101 "new_shipping_orderid_new_shipping_order@odata.bind": `/new_shipping_orders(${shippingId})`, // 订舱信息反馈单ID
102 "new_order_detailid@odata.bind": `/new_order_details(${orderDetail.new_order_detailid})`, // 整车销售订单明细
103 "new_productcode@odata.bind": `/new_product_fourths(${orderDetail._new_product_fourthid_value})`, // 产品代码
104 new_numberofsets: orderDetail.new_count, // 台数
105 new_timespan: new Date(orderDetail.new_expected_output_time).toISOString(), // 预计入库时间
106 new_paymentmethod: order.new_paymentmethod, // 付款方式
107 new_contractno: order.new_contractno, // 合同号
108 }
109 if (wayOfPackaging) {
110 //包装方式
111 shippingOrderDetail["new_way_of_packagingid@odata.bind"] = `/new_way_of_packagings(${orderDetail._new_way_of_packagingid_value})`
112 //单台长
113 shippingOrderDetail.new_singlelong = wayOfPackaging.new_long
114 //单台宽
115 shippingOrderDetail.new_singlelwide = wayOfPackaging.new_wide
116 //单台高
117 shippingOrderDetail.new_singlehigh = wayOfPackaging.new_high
118 }
119 Xrm.WebApi.createRecord("new_shipping_order_detail", shippingOrderDetail).then(
120 function success(result) {
121 resolve({ success: true })
122 },
123 function (error) {
124 resolve({ success: false, message: error.message })
125 }
126 );
127 })
128 }
思路就是,将所有的异步耗时操作都封装成Promise对象返回,Promise可以将异步转成同步,在执行完成后结果返回到then中,然后使用Promise.all将promise对象数组一起执行,全部执行完成后再统一返回信息。
JS中使用Promise.all控制所有的异步请求都完成后,在执行后续逻辑的更多相关文章
- 使用Promise发送多个异步请求, 全部完成后再执行
const datas = idList .map(id => url+'/id') .map(url => fetch(url).then(res => res.json())); ...
- js中的promise详解
一 概述 Promise是异步编程的一种解决方案,可以替代传统的解决方案--回调函数和事件.ES6统一了用法,并原生提供了Promise对象.作为对象,Promise有一下两个特点: (1)对象的 ...
- Three.js 中的参数调试控制插件dat.GUI.JS - [Three.js] - [dat.GUI]
不论是处于特殊功能的需要,还是处于效果调试方便,我们可能都需要修改模型中的参数值.在Three.js中,谷歌提供了一个js库,即dat.GUI.js用于处理这种需求. 通过该库,我们就不需要通过手动修 ...
- 在 JS 中使用 fetch 更加高效地进行网络请求
在前端快速发展地过程中,为了契合更好的设计模式,产生了 fetch 框架,此文将简要介绍下 fetch 的基本使用. 我的源博客地址:http://blog.parryqiu.com/2016/03/ ...
- 在 Node.js 中引入模块:你所需要知道的一切都在这里
本文作者:Jacob Beltran 编译:胡子大哈 翻译原文:http://huziketang.com/blog/posts/detail?postId=58eaf471a58c240ae35bb ...
- Promise.all处理多个异步请求
一个前台页面需要请求2个rest接口获取数据,一个用于解析文件获取列名,一个查询数据库获得列值. 有很低的概率页面显示为空,刷新可能就有显示了. 使用Promise.all就解决了上面的问题,2部分数 ...
- JS中的Promise
Promise 对象有以下两个特点. (1)对象的状态不受外界影响.Promise 对象代表一个异步操作,有三种状态:Pending(进行中).Resolved(已完成,又称 Fulfilled)和 ...
- Promise来控制JavaScript的异步执行
一般来说,js.html都是按照从上至下这种方式来进行执行的.这就造成了,基本上所有的执行过程都是在一个线程中进行. 我们都知道,ajax的使用大大的提高了前后台的沟通效率,那么有没有什么方式,让js ...
- js中实现页面跳转(返回前一页、后一页)
一:JS 重载页面,本地刷新,返回上一页 代码如下: <a href="javascript:history.go(-1)">返回上一页</a> <a ...
- js中宏任务,微任务,异步,同步,执行的顺序
[微任务]包括:Promise , process.nextTick() *node.js里面的 [宏任务]包括:整体代码script, setTimeout setInterval ...
随机推荐
- xtrabackup8.0.27备份失败
问题描述:mysql8.0.27备份出现中断,重新备份发现xtrabackup备份失败,xtrabackup与mysql版本不匹配,后来想起来时mysql进行了升级,8.0.27->8.0.29 ...
- Nvidia GPU热迁移-Singularity
1 背景 在GPU虚拟化和池化的加持下,可以显著提高集群的GPU利用率,同时也可以较好地实现弹性伸缩.但有时会遇到需要GPU资源再分配的场景,此时亟需集群拥有GPU任务热迁移的能力.举个简单的例子,比 ...
- Springboot整合Flowable6.x导出bpmn20
项目源码仓库 BPMN2.0(Business Process Model and Notation)是一套业务流程模型与符号建模标准,以XML为载体,以符号可视化业务,支持精准的执行语义来描述元素的 ...
- 《爆肝整理》保姆级系列教程-玩转Charles抓包神器教程(15)-Charles如何配置反向代理
1.简介 在App开发的过程当中,抓包是一个很常见的需求,而有些app的请求不会在网络设置代理时被抓到数据包,这里若是需要抓包就需要搭建反向代理. 2.什么是代理? 什么是代理,来一张图了解一下. 代 ...
- Appweb-6.1.1 移植到ARM
Appweb-6.1.1 移植到ARM 编译环境:ubuntu-12.04 x64 开发平台:Hi3535 arm版 编译版本:appweb-6.1.1.zip ESP下载地址=> ESP we ...
- .NET开源分布式锁DistributedLock
一.线程锁和分布式锁 线程锁通常在单个进程中使用,以防止多个线程同时访问共享资源. 在我们.NET中常见的线程锁有: 自旋锁:当线程尝试获取锁时,它会重复执行一些简单的指令,直到锁可用 互斥锁: Mu ...
- MQTT-保留消息和遗嘱消息
保留消息 为什么需要保留消息 如果不考虑持久会话的因素,那么MQTT订阅只有在客户端连接之后才能创建,所以服务端不能提前预知某个主题会被哪些服务端订阅或者某个客户端会订阅哪些主题,所以当消息到达服 ...
- 京喜APP - 图片库优化
作者:京东零售 何骁 介绍 京喜APP早期开发主要是快速原生化迭代替代原有H5,提高用户体验,在这期间也积累了不少性能问题.之后我们开始进行一些性能优化相关的工作,本文主要是介绍京喜图片库相关优化策略 ...
- 2021-11-04:计算右侧小于当前元素的个数。给你`一个整数数组 nums ,按要求返回一个新数组 counts 。数组 counts 有该性质: counts[i] 的值是 nums[i] 右
2021-11-04:计算右侧小于当前元素的个数.给你`一个整数数组 nums ,按要求返回一个新数组 counts .数组 counts 有该性质: counts[i] 的值是 nums[i] 右侧 ...
- pandas 数据处理 一些常用操作
读取csv文件,打印列名称: import pandas as pd # data = pd.read_csv("guba_fc_result_20230413.csv") dat ...