ES8异步/等待使JS开发人员的生活更加轻松,我正在转换我的旧代码来使用它,有一种情况,有些动作我不关心结果,就像我只想触发事件一样,不想等待它的结果,该如何处理呢?
可以这样说:
const doMyTasks = () => {
try {
//Do first task
let prom_t1 = util.promisify(myUpdateRecord);
let res_rec = await prom_t1();
//Do the second task
let prom_t2 = util.promisity(shootNotificationEmails);
//currently
await prom_t2(res_rec);
//Do the third task
let prom_t3 = util.promisfy(restHouseKeep);
await prom_t3();
} catch(error) {
console.log(`What hell is going on? ${error.message} [stack: ${error.stack}]`);
}
};对于第二个任务,我不想等待结果,我只想拍摄事件来触发电子邮件通知处理,跳到第三个任务,除了直接调用shotNotificationEmails w/o promisify之外,在ES8中还有什么更优雅的方法吗?
谢谢。:)
发布于 2021-07-30 16:12:09
您所要做的就是调用prom_t2(res_rec)而不使用await!这将允许doMyTasks继续运行,而无需等待prom_t2完成。
注意,这种模式的一个副作用是,prom_t2抛出的任何错误都不会在您的try/catch中捕获,而是会以全局未处理错误的形式出现。
https://stackoverflow.com/questions/68593951
复制相似问题