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链 – 是因为它令人困惑.

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

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

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...