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
Lepaskan: 2024-12-07 02:13:16
asal
1025 orang telah melayarinya

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);
Salin selepas log masuk

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
}
Salin selepas log masuk

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
}
Salin selepas log masuk
  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;
    }
}
Salin selepas log masuk
  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
});
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan