Korrekte Syntax für Try...Catch-Blöcke mit Async/Await
Bei Verwendung der praktischen Async/Await-Funktion in TypeScript tritt ein Problem auf ergibt sich bei der Deklaration von Variablen, wenn diese auf eine Antwort warten. Traditionell müssen sie außerhalb des try...catch-Blocks deklariert werden, um später verwendet zu werden, wie unten gezeigt:
let createdUser; try { createdUser = await this.User.create(userInfo); } catch (error) { console.error(error); } console.log(createdUser);
Es wurde vorgeschlagen, dass es eine bewährte Vorgehensweise ist, die Platzierung von Geschäftslogik innerhalb des try-Blocks zu vermeiden . Die Verwendung des empfohlenen Ansatzes erfordert jedoch die Deklaration der erwarteten Variablen außerhalb des Blocks, was umständlich sein kann.
Best Practice für die Fehlerbehandlung
Es gilt tatsächlich als Best Practice Vermeiden Sie es, mehrere Geschäftslogikzeilen im Try-Body zu platzieren, um sicherzustellen, dass alle aus dem Wert resultierenden Ausnahmen abgefangen werden. Ein umfassenderer Ansatz sieht wie folgt aus:
try { const createdUser = await this.User.create(userInfo); console.log(createdUser); // Business logic goes here } catch (error) { console.error(error); // Exception from creation or business logic }
Alternativen für die selektive Fehlerbehandlung
Es gibt drei Alternativen, wenn Sie nur Fehler abfangen und behandeln möchten, die von der Versprechen:
let createdUser; // Or use 'var' inside the block try { createdUser = await this.User.create(userInfo); } catch (error) { console.error(error); // Exception from creation } if (createdUser) { // User was created successfully console.log(createdUser); // Business logic goes here }
try { const createdUser = await this.User.create(userInfo); console.log(createdUser); // Business logic goes here } catch (error) { if (error instanceof CreationError) { console.error(error); // Exception from creation } else { throw error; } }
await this.User.create(userInfo).then(createdUser => { // User was created successfully console.log(createdUser); // Business logic goes here }, error => { console.error(error); // Exception from creation });
Das obige ist der detaillierte Inhalt vonWie behandelt man Fehler in Async/Await Try...Catch-Blöcken in TypeScript am besten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!