如何解决在没有.then的情况下执行两个函数
当前我有以下代码:
client.clearStore()
.then(() => someFunction())
.catch(e => logger.error('error',e));
可以,但是我在使用.then()
进行测试时遇到了问题,因此我想知道是否还有另一种方法可以同时执行client.clearStore()
和someFunction()
,但已经完成了{{1} }返回承诺。
解决方法
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function
(async () => {
try {
const someFunction = await client.clearStore();
someFunction();
} catch (e) {
logger.error('error',e);
}
})();
,
您可以像这样使用await
关键字
(async () => {
await client.clearStore();
someFunction()
});
,
try {
await client.clearStore();
someFunction()
} catch (e) {
logger.error('error',e)
}
但是“ then”的解决方案对我来说看起来更好,并且可以异步执行(从理论上讲,在等待“ clearStore”完成时正在执行主线程)。我想您在模拟“ clearStore”以返回承诺时遇到问题吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。