Rumah >hujung hadapan web >tutorial js >Bolehkah Async/Await dan .then/.catch Digunakan Bersama untuk Pengendalian Ralat dalam JavaScript?
Menggunakan Async/Await dan .then/.catch
Async/wait dan .then/.catch ialah kedua-dua mekanisme pengendalian ralat dalam JavaScript . Walaupun async/await lebih ringkas dan moden, .then/.catch kekal sebagai pilihan yang berdaya maju. Bolehkah menggunakannya bersama-sama memberikan apa-apa faedah atau kelemahan?
Coretan kod yang anda berikan mempamerkan senario di mana kedua-dua mekanisme digunakan bersama. Walau bagaimanapun, jawapannya mencadangkan untuk menggantikan try/catch dengan gabungan async/wait dan .catch. Ini memudahkan kod dan menyimpannya dalam skop segerak yang ditetapkan oleh fungsi async.
Berikut ialah contoh:
<code class="javascript">async function asyncTask() { throw new Error('network'); } async function main() { const result = await asyncTask().catch(error => console.error(error)); console.log('result:', result); } main();</code>
Dalam contoh ini, asyncTask membuang ralat, yang dikendalikan oleh .catch block dalam kaedah async utama. Ralat dilog ke konsol, manakala pelaksanaan diteruskan dengan baris seterusnya, di mana pembolehubah hasil ditetapkan kepada tidak ditentukan kerana fungsi tidak mengembalikan nilai eksplisit.
Kesimpulannya, semasa menggunakan kedua-dua async/wait dan . then/.catch together mungkin tidak mengakibatkan sebarang kemudaratan, biasanya disyorkan untuk menggunakan gabungan async/wait dan .catch yang lebih ringkas dan moden untuk pengendalian ralat dalam fungsi async. Pendekatan ini memastikan kekompakan kod dan mengekalkan skop segerak yang ditetapkan oleh kata kunci async.
Atas ialah kandungan terperinci Bolehkah Async/Await dan .then/.catch Digunakan Bersama untuk Pengendalian Ralat dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!