Apabila pembangun menggunakan Ajax jQuery untuk membuat permintaan rangkaian, kadangkala kita perlu membuat permintaan segerak Contohnya, dalam beberapa kes, kita perlu menunggu hasil permintaan sebelum melaksanakan operasi lain. Walau bagaimanapun, dalam Ajax, permintaan segerak mempunyai kecacatan, iaitu, permintaan segerak akan mengunci penyemak imbas, menghalang pengguna daripada melakukan operasi lain sehingga permintaan selesai atau tamat masa.
Jadi bagaimana untuk menyelesaikan masalah ini? Kita boleh menyelesaikan masalah ini dengan menulis fungsi yang boleh menghidupkan dan mematikan permintaan segerak, supaya apabila permintaan segerak diperlukan, ia boleh dihidupkan dan dimatikan apabila tidak diperlukan.
Seterusnya, mari lihat cara melaksanakan fungsi ini.
Pertama, kita perlu menentukan pembolehubah untuk menyimpan status semasa sama ada permintaan segerak diperlukan:
var isSync = false;
Seterusnya, kami mentakrifkan fungsi untuk menetapkan status permintaan segerak:
function setSync(status) { isSync = status; }
Antaranya, parameter status ialah nilai Boolean, menunjukkan status permintaan penyegerakan yang perlu ditetapkan.
Seterusnya, kami perlu memantau setiap permintaan Ajax dan membuat pertimbangan sebelum permintaan Jika status semasa adalah permintaan segerak, maka kami akan menetapkannya sebagai permintaan segerak; permintaan tak segerak .
$(document).ajaxSend(function(event, xhr, options) { if (isSync) { options.async = false; // 设置同步请求 } else { options.async = true; // 设置异步请求 } });
Akhir sekali, kami perlu menetapkan status kepada permintaan tak segerak selepas setiap permintaan Ajax selesai untuk menghalang permintaan seterusnya daripada diproses sebagai permintaan segerak.
$(document).ajaxComplete(function(event, xhr, options) { options.async = true; // 设置为异步请求 });
Sekarang kita telah menentukan fungsi yang boleh menghidupkan dan mematikan permintaan segerak, maka apabila kita perlu menggunakan permintaan segerak, kita boleh memanggil setSync(true) untuk menghidupkan permintaan segerak dan memanggil setSync(false) untuk mematikan bertanya.
Sebagai contoh, kod berikut melaksanakan permintaan segerak:
setSync(true); // 开启同步请求 $.ajax({ url: '/api/data', type: 'GET', dataType: 'json', success: function(data) { console.log(data); // 处理返回结果 }, error: function(xhr, errorType, error) { console.error(error); // 处理请求错误 } }); setSync(false); // 关闭同步请求
Dalam pembangunan sebenar, kita harus cuba mengelak daripada menggunakan permintaan segerak, kerana permintaan segerak akan menjejaskan pengalaman pengguna. Walau bagaimanapun, dalam beberapa kes, seperti log masuk dan operasi lain yang mesti menunggu hasilnya, kita boleh menggunakan kaedah di atas untuk menyelesaikan masalah permintaan segerak mengunci penyemak imbas.
Ringkasnya, apabila menggunakan Ajax untuk membuat permintaan rangkaian, kita harus mengendalikan permintaan segerak dengan sangat berhati-hati untuk mengelak daripada menjejaskan pengalaman pengguna.
Atas ialah kandungan terperinci jquery ajax kunci permintaan segerak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!