主頁 > 企業開發 > JS中使用Promise.all控制所有的異步請求都完成后,在執行后續邏輯

JS中使用Promise.all控制所有的異步請求都完成后,在執行后續邏輯

2023-07-11 08:10:27 企業開發

使用場景為,在js中連續的幾個異步耗時操作,后面的耗時操作需要使用第一個操作的回傳結果,例如呼叫ajax異步介面,需要先創建完主表,然后拿到主表id在去回圈創建明細表,等全部創建完成后,彈出提示來,或者失敗提示, 通常情況,在耗時操作完成后在去呼叫,需要將異步方法轉成同步方法,結合回呼函式,像ajax請求可以直接設定為同步,然后再呼叫完成的回呼函式里繼續去呼叫另一個邏輯代碼,但這樣就會導致代碼嵌套比較多,不易拓展和維護,使用Promise.all可以減少代碼里的不斷嵌套,直接上代碼,具體的一看代碼就明白了,promise的使用有單獨的筆記整理,
  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 =https://www.cnblogs.com/adingfirstlove/p/ {
 58                     new_paymentmethod: res.data["[email protected]"],
 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 =https://www.cnblogs.com/adingfirstlove/p/ 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             "[email protected]": `/new_shipping_orders(${shippingId})`,       // 訂艙資訊反饋單ID
102             "[email protected]": `/new_order_details(${orderDetail.new_order_detailid})`,          // 整車銷售訂單明細
103             "[email protected]": `/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["[email protected]"] = `/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物件陣列一起執行,全部執行完成后再統一回傳資訊,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/556972.html

標籤:JavaScript

上一篇:【一步步開發AI運動小程式】十二、自定義一個運動分析器,實作計時計數02

下一篇:返回列表

標籤雲
其他(162352) Python(38273) JavaScript(25530) Java(18294) C(15239) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7292) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4615) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) HtmlCss(1995) .NET技术(1986) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1882) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • JS中使用Promise.all控制所有的異步請求都完成后,在執行后續邏輯

    將所有的異步耗時操作都封裝成Promise物件回傳,Promise可以將異步轉成同步,在執行完成后結果回傳到then中,然后使用Promise.all將promise物件陣列一起執行,全部執行完成后再統一回傳資訊 ......

    uj5u.com 2023-07-11 08:10:27 more
  • 【一步步開發AI運動小程式】十二、自定義一個運動分析器,實作計時

    > 隨著人工智能技術的不斷發展,阿里體育等IT大廠,推出的“樂動力”、“天天跳繩”AI運動APP,讓**云上運動會、線上運動會、健身打卡、AI體育指導**等概念空前火熱。那么,能否將這些在APP成功應用的場景搬上小程式,分享這些概念的紅利呢?本系列文章就帶您一步一步從零開始開發一個AI運動小程式,本 ......

    uj5u.com 2023-07-11 08:10:19 more
  • 前端Vue自定義商品訂單tabs標題欄選項卡組件 可設定文字下劃線顏

    隨著技術的發展,開發的復雜度也越來越高,傳統開發方式將一個系統做成了整塊應用,經常出現的情況就是一個小小的改動或者一個小功能的增加可能會引起整體邏輯的修改,造成牽一發而動全身。 通過組件化開發,可以有效實作單獨開發,單獨維護,而且他們之間可以隨意的進行組合。大大提升開發效率低,降低維護成本。 組件化 ......

    uj5u.com 2023-07-11 08:09:57 more
  • SQ工具|5|界址點順時針編號

    順時針編碼工具,是以宗地節點的起始點為起點,沿著宗地的邊,對界址點進行順時針編碼。 點擊順時針編碼工具,界面如圖所示 界面介紹: 1.首尾去重,當同屬于一個宗地的界址點在起始點存在重復時,勾選此功能可去除重復點編號。 2.編號帶'J':為界址點的編號前加一個'J'字符。 3.內環順時針:當孔狀圖斑的 ......

    uj5u.com 2023-07-11 08:09:34 more
  • SQ工具|4|宗地節點重排|西北點起始點

    在要求圖斑的起始點為西北節點時,可使用該工具完成對要素節點的處理 此工具的西北點定義為:以目標要素的外包矩的左上點為基準,距離此基準點最近的點定義為西北點,設為起始點 方式一: 打開西北節點(自動賦值)工具,如下圖所示: 圖層選擇待處理的圖層,約束條件為約束將重排的圖斑,如需全部要素重新排列,為空即 ......

    uj5u.com 2023-07-11 08:09:18 more
  • SQ工具|3|界址點線生成|ZDZHDM賦值

    以 不動產登記資料庫TD/T 1066-2021 資料庫規范中的宗地及界址點線為依據 界面介紹: 此工具主要實作了界址線屬性的計算,以ZDZHDM(記錄相鄰界址點、界址線的宗地代碼)為主,所需資料包括對應的宗地資料 界址點自動賦值包括: 界址線自動賦值包括: 如果缺少界址點、界址線資料,點擊生成界址 ......

    uj5u.com 2023-07-11 08:09:05 more
  • 4.8 x64dbg 學會掃描應用堆疊

    LyScript 插件中提供了針對堆疊的操作函式,對于堆的開辟與釋放通常可使用`create_alloc()`及`delete_alloc()`在之前的文章中我們已經使用了堆創建函式,本章我們將重點學習針對堆疊的操作函式,堆疊操作函式有三種,其中`push_stack`用于入堆疊,`pop_stack`用... ......

    uj5u.com 2023-07-11 08:08:55 more
  • SQ工具|2|ArcGIS資料結構(欄位名稱、欄位長度、欄位型別、允許為

    方式一:借用ArcToolBox中的合并工具(方法來自于GIS思維) 資料管理工具>>常規>>合并 右側四個按鈕可實作添加欄位、洗掉欄位及調整字順序的需求 右擊目標欄位,點擊屬性,即可實作更改欄位名稱、型別、長度及允許空值的功能。 點擊確定后即可生成所需資料。 但!我們使用的ArcGIS幾乎都是慈禧 ......

    uj5u.com 2023-07-11 08:08:44 more
  • 4.7 x64dbg 應用層的鉤子掃描

    所謂的應用層鉤子(Application-level hooks)是一種編程技術,它允許應用程式通過在特定事件發生時執行特定代碼來自定義或擴展其行為。這些事件可以是用戶互動,系統事件,或者其他應用程式內部的事件。應用層鉤子是在應用程式中添加自定義代碼的一種靈活的方式。它們可以用于許多不同的用途,如安... ......

    uj5u.com 2023-07-11 08:08:33 more
  • ENVI實作QUAC、簡化黑暗像元、FLAASH方法的遙感影像大氣校正

    本文介紹基于**ENVI**軟體,實作對**Landsat 7**遙感影像加以**預處理**與多種不同**大氣校正**方法的操作。 [TOC](基于ENVI的Landsat 7影像處理與多種大氣校正方法對比) # 1 資料匯入與輻射定標 關于資料的下載,網路中相關資源很多,這里不再贅述。 在我們所獲 ......

    uj5u.com 2023-07-11 08:07:40 more