如何解决如何删除setTimeout并在angular中使用async await方法
如果我从下面提到的代码中删除了setTimeout
表单,则代码块(getUnderlyingData)正在运行上一个响应之前。所以我没有得到适当的回应。请任何人帮我解决这个问题。
当前代码:
await this.TableauService.initViz(this.TableauViz,this.DataContainer,this.DataURL).then(([uniqData,TableauViz]) => {
this.VizWorkbook = TableauViz;
setTimeout(() => {
this.SheetData = this.TableauService.getUnderlyingData(TableauViz,"KPI",(response) => {
console.log("sheet data",response);
});
},7000);
});
}
解决方法
如果您使用await
,则无需使用then
来解决承诺,await
会为您完成。
一个异步函数可以包含一个await
表达式,该表达式暂停异步函数的执行并等待所传递的Promise的解析,然后它恢复异步函数的执行并返回解析的值。
async functionName(){
let result = await this.TableauService.initViz(this.TableauViz,this.DataContainer,this.DataURL)
}
上面的result
变量保留您的已解析值,您可以根据需要进行任何操作。
或者您也可以在this.VizWorkbook = TableauViz;
内添加此行getUnderlyingData(.. { this.VizWorkbook = TableauViz; ... }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。