现在我有step1, step2,step3,step4四个操作,都用promise了
逻辑是只要有一个step成功就返回,不用执行下面的操作,有一个失败,就执行下面的操作,例如,step1失败,执行step2,如果成功,就不用执行下面的step3了
以上操作用promise如何写比较好呢?
现在我有step1, step2,step3,step4四个操作,都用promise了
逻辑是只要有一个step成功就返回,不用执行下面的操作,有一个失败,就执行下面的操作,例如,step1失败,执行step2,如果成功,就不用执行下面的step3了
以上操作用promise如何写比较好呢?
var p1 = new Promise(function (resolve, reject) {
// ...
});
var p2 = new Promise(function (resolve, reject) {
// ...
resolve(p1);
})
嗯 楼上说的对 用 async function
比较方便
// 假设步骤如下
const api = 'http://api.hitokoto.cn/?c=a'
const asyncFunctions = {
async step1() { return await fetch(api).then(res => res.json()) },
async step2() { return await fetch(api).then(res => res.json()) },
async step3() { return await fetch(api).then(res => res.json()) },
async step4() { return await fetch(api).then(res => res.json()) },
}
;(async () => {
let result = null
for(let step in asyncFunctions) {
try {
result = await asyncFunctions[step]()
break
} catch(err) {
console.error(err)
}
}
console.info(result)
})()
27 回答13k 阅读
8 回答3.5k 阅读✓ 已解决
6 回答1.3k 阅读✓ 已解决
5 回答5.3k 阅读✓ 已解决
4 回答1.6k 阅读✓ 已解决
3 回答1.7k 阅读
4 回答2.3k 阅读✓ 已解决
成功了reject的方案中,你需要找到一个办法区分成功流程,和代码运行过程中发生的错误。
比如step3里面出现了一个无法预估的异常,抛出了一个错误,这个时候对正常流程的处理和对异常流程的处理都混在promise给你提供的对异常流程的接口中了。
不要用异常处理逻辑来做正常处理流程,这个规则保证了代码可读性与可维护性。
用promise的方案很简单。此外,正常处理流程(
console.log("Done")
)和异常处理流程(console.error("Done, but all failed")
)可以清晰地分辨出:切换step1、step2……的返回就可以查到所有流程: