Pengenalan fetch() dalam JavaScript telah merevolusikan pengendalian permintaan HTTP, menyediakan antara muka yang serba boleh dan intuitif. Walau bagaimanapun, kebimbangan sering timbul mengenai keupayaan untuk menamatkan permintaan ini lebih awal.
Sehingga September 2017, fetch() menggabungkan peningkatan ketara: sokongan untuk parameter isyarat . Parameter ini membenarkan pembangun membatalkan permintaan menggunakan AbortController dan AbortSignal yang sepadan. Pada mulanya, sokongan penyemak imbas adalah terhad, tetapi kini (sehingga Mac 2020), kebanyakan penyemak imbas utama (Edge, Firefox, Chrome, Safari, Opera dan lain-lain) menerima sepenuhnya fungsi ini.
Proses pembatalan melibatkan empat langkah:
const controller = new AbortController()
const signal = controller.signal
fetch(urlToFetch, { method: 'get', signal: signal, })
controller.abort();
Untuk menggambarkan cara ia berfungsi dalam amalan, pertimbangkan contoh berikut:
// Create an instance. const controller = new AbortController() const signal = controller.signal /* // Register a listenr. signal.addEventListener("abort", () => { console.log("aborted!") }) */ function beginFetching() { console.log('Now fetching'); var urlToFetch = "https://httpbin.org/delay/3"; fetch(urlToFetch, { method: 'get', signal: signal, }) .then(function(response) { console.log(`Fetch complete. (Not aborted)`); }).catch(function(err) { console.error(` Err: ${err}`); }); } function abortFetching() { console.log('Now aborting'); // Abort. controller.abort() }
Dengan menggunakan controller.abort() , permintaan boleh diganggu pada bila-bila masa.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengganggu Permintaan Pengambilan HTTP dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!