Rumah > hujung hadapan web > tutorial js > Memahami Kepentingan res.ok dalam Fetch API

Memahami Kepentingan res.ok dalam Fetch API

Patricia Arquette
Lepaskan: 2024-12-17 14:15:16
asal
477 orang telah melayarinya

Understanding the Importance of res.ok in Fetch API

Saya sentiasa menjadi pengguna tegar Axios untuk pengambilan data, tetapi baru-baru ini saya memutuskan untuk menggunakan API Ambil. Semasa menerokainya, saya menemui perbezaan halus tetapi ketara yang saya fikir patut dikongsi.

Mari mulakan dengan coretan kod ini. Apa yang anda fikir ia log masuk?

try{
   //this returns a 404 error
   const res = await fetch("randomapi....") 
   console.log("successful")
  }catch(err){
   console.log("failed", err)
}
Salin selepas log masuk

Jika anda meneka ia akan "gagal" log bersama dengan objek ralat pada konsol, anda tidak bersendirian—saya fikir perkara yang sama sehingga baru-baru ini. Walau bagaimanapun, itu bukan cara Ambil berfungsi!

Berikut ialah tangkapan: walaupun permintaan Ambil menerima kod status 404 atau 500, ia tidak menimbulkan ralat dan tidak mencetuskan blok tangkapan. Sebaliknya, fungsi ambil menyelesaikan janji, menyerahkan kepada anda untuk menyemak sama ada respons berjaya.

Untuk mengendalikan ralat dengan Fetch dengan betul, anda perlu menyemak sifat res.ok secara eksplisit, seperti:

try{
    //returns 404 error
    const res = await fetch("randomapi")
    if(!res.ok){
      throw new Error("fetch request failed")
    }
    console.log("successful")
    let data = await res.json()
    console.log(data)
}catch(err){
  console.log(err)
}
Salin selepas log masuk

Dengan pendekatan ini, jika status respons berada di luar julat yang berjaya (200–299), pernyataan lontaran dilaksanakan dan ralat ditangkap dalam blok tangkapan.

Mengapa Ini Berlaku?

Tidak seperti Axios, Fetch tidak menganggap kod respons HTTP di luar julat 2xx sebagai ralat. Sebaliknya, ia menganggap semua respons HTTP, berjaya atau tidak, sebagai janji yang dipenuhi. Pilihan reka bentuk ini memberikan pembangun lebih kawalan tetapi juga memerlukan usaha tambahan untuk mengendalikan ralat dengan betul.

Memahami respons.ok

Harta response.ok ialah boolean yang menilai kepada true untuk kod status HTTP antara 200 hingga 299. Untuk mana-mana kod status lain, ia menilai kepada false. Ini menjadikannya cara yang mudah dan boleh dipercayai untuk menyemak sama ada permintaan pengambilan anda berjaya.

Contohnya:

  • Status 200 menunjukkan kejayaan dan akan menetapkan respons.ok kepada benar.
  • Status 404 (tidak ditemui) atau 500status (ralat pelayan) akan ditetapkan respons.ok kepada palsu.

Anda juga boleh mengakses kod status secara terus menggunakan response.status jika anda memerlukan pengendalian ralat yang lebih terperinci, seperti membezakan antara ralat sisi klien (4xx) dan ralat sisi pelayan (5xx).

Terima kasih kerana membaca dan saya harap ini membantu seseorang di luar sana!

Atas ialah kandungan terperinci Memahami Kepentingan res.ok dalam Fetch API. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
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