react+antd4實現(xiàn)優(yōu)化大批量接口請求
背景
接到一個需求,需要做一個運維的功能,對公司下平臺子系統(tǒng)做一個開關界面,要求可以大批量對系統(tǒng)進行修改。這樣大批量的修改,如果有個老哥手一抖點了全選,那可能同時會發(fā)送幾十上百個接口,對瀏覽器和服務器都會是一個比較大的負擔。
相似的應用場景還有:文件批量上傳等
使用技術棧:react hooks + antd4
分析
維護一個任務池,先默認發(fā)出最大并發(fā)數(shù)量的接口請求,一個蘿卜一個坑,當上一個請求結束(無論成功失?。?,則讓下一個請求進入任務隊列,之道所有請求列表都請求完成,返回這個任務池的最終結果。
部分代碼實現(xiàn)
主要業(yè)務邏輯
// ... 點擊確定,先進行前置校驗 const onSubmitHandle = (event) => { event.preventDefault(); // 防止觸發(fā)原生submit,導致瀏覽器頁面刷新 validateFields((err, values) => { // 校驗通過 if(!err){ // 通過遍歷組裝參數(shù) const arrParam = concateDynamicParams(values); concurrentControl(arrParm, 5) .then(res)=> { // 獲取成功列表和失敗列表 const { sucSystem, faildSystem } = getSucAndFailedResult(res); const content = ( <p> {'修改成功的系統(tǒng):'} <br /> {`${sucSystem}`} <br /> {'修改失敗的系統(tǒng):'} <br /> {`${faildSystem}`} </p> ); Modal.info({ title: "提示", content, oKText: "確定", }) // 取消loading,重置列表等操作... } } }) }
維護任務池,控制并發(fā)數(shù)
const concurrentControl = (arrParam, maxNum = 10) => new Promise((resolve) => { // 無任務數(shù)據時 if(!arrParam.length){ resolve([]); return; } const results = []; // 最終的結果集合,用于保存接口返回的信息 let index = 0; // 用于記錄下一個接口下標 let count = 0; // 用于記錄發(fā)送了多少條數(shù)據 const request = async () => { if(index === arrParam.length) return; // 出口 const i = index; // 當前下標(備份) // 組裝請求路徑與參數(shù) const url = arrParam[i].url; const param = arrParam[i].data; index++; // 預先記錄下一個請求的下標 try{ // 發(fā)送請求 const resp = await dispatchSqlGuardSwitchProcess(url, param); result[i] = resp; // 記錄返回結果 } catch( error ){ result[i] = error; } finally { count++ ; // 當前接口完成,下一個接口調用開始 if(count === arrParam.length){ // 全部任務池中的接口都調用完畢 resolve(results) } request()(); // 繼續(xù)下一個請求 } } // 初始化請求數(shù) const maxParallelRequests = Math.min(maxNum, arrParam.length); for(let i = 0; i < maxParallelRequests; i++){ request() } })
總結
核心思想是一個蘿卜一個坑,直到所有的蘿卜都從坑里出來。(誤)
通過維護一個任務池,標記當前請求,下一個請求,以及當前總共請求的次數(shù),便可以做到前端控制并發(fā)的需求場景。
參考資料:關于前端:如何實現(xiàn)并發(fā)請求數(shù)量控制?
到此這篇關于react+antd4實現(xiàn)優(yōu)化大批量接口請求的文章就介紹到這了,更多相關react優(yōu)化請求內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解React如何優(yōu)雅地根據prop更新state值
這篇文章主要為大家詳細介紹了React如何優(yōu)雅地實現(xiàn)根據prop更新state值,文中的示例代碼講解詳細,具有一定的參考價值,感興趣的小伙伴可以了解下2023-11-11詳解在create-react-app使用less與antd按需加載
這篇文章主要介紹了詳解在create-react-app使用less與antd按需加載,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12React系列useSyncExternalStore學習詳解
這篇文章主要為大家介紹了React系列useSyncExternalStore的學習及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07react-beautiful-dnd拖拽排序功能的實現(xiàn)過程
這篇文章主要介紹了react-beautiful-dnd拖拽排序功能的實現(xiàn)過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07