Rumah  >  Artikel  >  hujung hadapan web  >  Bila Menggunakan Promise.reject Daripada Membuang?

Bila Menggunakan Promise.reject Daripada Membuang?

Patricia Arquette
Patricia Arquetteasal
2024-10-24 05:25:30219semak imbas

When to Use Promise.reject Instead of Throw?

Promise.reject vs. throw: Membongkar Perbezaan

Dilema biasa dalam pembangunan JavaScript ialah memahami perbezaan antara Promise.reject dan throwing satu kesilapan. Walaupun kedua-dua strategi boleh digunakan untuk mengendalikan ralat, perbezaan halus muncul dalam senario tertentu.

Dalam konteks panggilan balik janji, penggunaan lontaran secara berkesan menandakan ralat dan pengendali tangkapan berikut akan menangkapnya. Walau bagaimanapun, apabila bekerja di luar panggilan balik janji, pengendali tangkapan tidak akan dipanggil jika lontaran digunakan. Untuk membetulkannya, Promise.reject mesti digunakan sebaliknya.

Pertimbangkan kod berikut:

Menggunakan Promise.reject:

<code class="javascript">return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            return Promise.reject(new PermissionDenied());
        }
    });</code>

Menggunakan lontaran:

<code class="javascript">return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            throw new PermissionDenied();
        }
    });</code>

Dalam contoh di atas, pendekatan lontaran akan mencetuskan pengendali tangkapan dalam sebarang panggilan balik janji. Walau bagaimanapun, jika asyncIsPermitted() bukan janji dan sebaliknya merupakan fungsi yang melaksanakan pemprosesan tak segerak (menggunakan setTimeout atau serupa), lontaran tidak akan dikendalikan oleh tangkapan. Dalam kes sedemikian, Promise.reject harus digunakan untuk memastikan ralat ditangkap.

Oleh itu, walaupun lontaran mungkin lebih disukai kerana singkatnya, Promise.reject menawarkan lebih fleksibiliti dan harus digunakan apabila perlu untuk memastikan pengendalian ralat dalam konteks panggil balik bukan janji.

Atas ialah kandungan terperinci Bila Menggunakan Promise.reject Daripada Membuang?. 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