使用 Async/Await 的 Try...Catch 块的正确语法
由 Async/Await 促进的 JavaScript 异步编程提供了处理异步操作的便捷方法。然而,在 try...catch 块中声明的变量的放置引发了有关最佳实践的问题。
在提供的示例中,变量createdUser 在 try...catch 块之外声明,以允许在等待表达。但是,通常不鼓励在 try 主体中合并多行业务逻辑。
最佳实践
首选方法是将所有异步操作封装在try 块,确保拦截任何异常。这允许全面的错误处理并防止逻辑放置在 try 块之外。
try { const createdUser = await this.User.create(userInfo); // Business logic can be placed here as exceptions will be caught. console.log(createdUser); // ... additional business logic ... } catch (error) { console.error(error); // Handle error from creation or business logic. }
替代选项
如果必须将错误处理与业务逻辑分开,请考虑这些替代方案:
虽然 JavaScript 本身不支持条件异常语法,但可以通过在内部重新抛出异常来实现自定义错误处理.catch() 处理程序(如有必要)。
以上是如何在 JavaScript 中使用 Async/Await 正确构造 Try...Catch 块?的详细内容。更多信息请关注PHP中文网其他相关文章!