Rumah >hujung hadapan web >tutorial js >Cara Terbaik Mengendalikan Ralat dalam Async/Menunggu Cuba...Tangkap Blok dalam 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:
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 });
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!