Heim >Web-Frontend >js-Tutorial >Wie behandelt man Fehler in Async/Await Try...Catch-Blöcken in TypeScript am besten?

Wie behandelt man Fehler in Async/Await Try...Catch-Blöcken in TypeScript am besten?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-07 02:13:161014Durchsuche

How to Best Handle Errors in Async/Await Try...Catch Blocks in TypeScript?

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:

  1. Deklarieren Sie die Variable außerhalb und verzweigen Sie: Dies beinhaltet eine Verzweigung, je nachdem, ob Es ist eine Ausnahme aufgetreten, wie unten gezeigt:
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
}
  1. Testen Sie den Ausnahmetyp:Testen Sie die abgefangene Ausnahme auf ihren spezifischen Typ und behandeln Sie sie entsprechend oder lösen Sie sie erneut aus:
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;
    }
}
  1. Dann mit Rückrufen verwenden: Dieser Ansatz verwendet zwei Rückrufe anstelle von Try/Catch, was die einfachste und am meisten empfohlene Lösung bietet:
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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn