javascript – 等待承诺链有什么问题?

我正在研究一个Angular 6应用程序,我被告知以下是一个反模式:

await someFunction().then(result => {
    console.log(result);
});

我意识到等待承诺链是毫无意义的.如果someFunction()返回一个promise,那么如果你正在等待它,则不需要一个promise链.你可以这样做:

const result = await someFunction();
console.log(result);

但我被告知等待一个承诺链可能会导致错误,或者它会破坏我的代码中的东西.如果上面的第一个代码片段与第二个代码段完全相同,那么使用哪个代码片段至关重要.第一个片段引入了哪个危险,第二个片段没有?

最佳答案
在引擎盖下,async / await就是承诺.

也就是说,当你有一些看起来像这样的代码时:

const result = await myAsyncFunction();   
console.log(result): 

这和写作完全一样:

myAsyncFunction().then(data => {
   const result = data; 
   console.log(result); 
}); 

之所以 – 你不应该混合async / await和.then链 – 是因为它令人困惑.

最好选择一种风格,并坚持下去.

当你选择一个时 – 你也可以选择异步/等待 – 这更容易理解.

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面