Rumah >hujung hadapan web >tutorial js >Cara Terbaik Mengendalikan Ralat dalam Async/Menunggu Cuba...Tangkap Blok dalam TypeScript?

Cara Terbaik Mengendalikan Ralat dalam Async/Menunggu Cuba...Tangkap Blok dalam TypeScript?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-07 02:13:16963semak imbas

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

Sintaks yang Betul untuk Cuba...Catch Blocks dengan Async/Await

Apabila menggunakan ciri Async/Await yang mudah dalam TypeScript, satu isu timbul mengenai pengisytiharan pembolehubah apabila mereka menunggu tindak balas. Secara tradisinya, mereka mesti diisytiharkan di luar percubaan...catch block untuk digunakan kemudian, seperti yang ditunjukkan di bawah:

let createdUser;
try {
    createdUser = await this.User.create(userInfo);
} catch (error) {
    console.error(error);
}

console.log(createdUser);

Adalah dicadangkan bahawa amalan terbaik untuk mengelak daripada meletakkan logik perniagaan dalam blok try . Walau bagaimanapun, menggunakan pendekatan yang disyorkan memerlukan pengisytiharan pembolehubah yang ditunggu di luar blok, yang boleh menyusahkan.

Amalan Terbaik untuk Pengendalian Ralat

Ia sememangnya dianggap sebagai amalan terbaik untuk elakkan meletakkan berbilang baris logik perniagaan di dalam badan percubaan untuk memastikan semua pengecualian yang timbul daripada nilai ditangkap. Pendekatan yang lebih komprehensif adalah seperti berikut:

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
}

Alternatif untuk Pengendalian Ralat Terpilih

Terdapat tiga alternatif jika anda ingin hanya menangkap dan mengendalikan ralat yang berpunca daripada janji:

  1. Isytiharkan Pembolehubah Luar dan Cawangan: Ini melibatkan percabangan bergantung pada sama ada pengecualian berlaku, seperti yang ditunjukkan di bawah:
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. Uji Jenis Pengecualian: Uji pengecualian yang ditangkap untuk jenis dan pemegangnya yang khusus atau buang semula dengan sewajarnya:
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. Gunakan kemudian dengan Panggilan balik: Pendekatan ini menggunakan dua panggilan balik dan bukannya cuba/tangkap, memberikan penyelesaian yang paling mudah dan paling disyorkan:
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
});

Atas ialah kandungan terperinci Cara Terbaik Mengendalikan Ralat dalam Async/Menunggu Cuba...Tangkap Blok dalam TypeScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn