我這裡的用例:
#有更好的設計模式嗎?
let twoStagePromise = (state: boolean): Promise<{ ready: boolean, wait: Promise<any>; }> => { return new Promise((resolve, reject) => { try { if (state) { resolve({ ready: true, wait: new Promise((resolve, reject) => { resolve([1, 2, 3]); }) }); } else { resolve({ ready: false, wait: new Promise((resolve, reject) => { setTimeout(() => { resolve([1, 2, 3]); }, 1000); }) }); } } catch (e) { reject(e); } }); }; twoStagePromise(false).then((data) => { if (!data.ready) { console.log('loading...'); } return data.wait; }).then((result) => { console.log("recieved result", result); }).catch((error) => { console.log("try-catch failed or inner promise failed") });
閱讀了一些評論後,我大大簡化了程式碼:
let twoStagePromise = (state: boolean): Promise<number[] | Promise<number[]>> => { return new Promise((resolve, reject) => { try { if (state) { resolve([1, 2, 3]); } else { resolve(new Promise((resolve) => setTimeout(() => { resolve([1,2,3]) }, 1000))) } } catch (e) { reject(e); } }); }; twoStagePromise(false).then((dataOrPromise) => { if (dataOrPromise instanceof Promise) { console.log('loading...'); } return dataOrPromise // continue the promise chain by returning the promise or data }).then((result) => { console.log("recieved result", result); }).catch((error) => { console.log("try-catch failed or inner promise failed", error) });
您可以建立一個明確傳回值或其承諾的函數。無論如何你都可以輕鬆地
await
了。若要檢查結果是否同步,請使用result instanceof Promise