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

前端之家收集整理的这篇文章主要介绍了javascript – 等待承诺链有什么问题?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

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

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

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

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

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

这和写作完全一样:

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

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

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

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

猜你在找的JavaScript相关文章