Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mencegah Penyerahan Borang Berganda dalam jQuery: Teknik Apakah yang Paling Berfungsi?
Cara Mencegah Penyerahan Borang Berganda dalam jQuery
Apabila bekerja dengan borang yang mengambil masa yang lama untuk diproses, menghalang pengguna daripada tidak sengaja menghantar borang beberapa kali adalah penting. Artikel ini membincangkan kaedah untuk mencapai ini menggunakan jQuery.
Percubaan Awal
Pendekatan awal melibatkan melumpuhkan semua input dan butang semasa penyerahan borang. Walau bagaimanapun, teknik ini menyebabkan borang tidak diserahkan dalam Firefox.
Penyelesaian Yang Diperbaiki
Penyelesaian terletak pada melumpuhkan secara terpilih hanya butang hantar, kerana melumpuhkan semua input mungkin mengganggu penghantaran borang. Kod jQuery berikut mencapai ini:
$('button[type=submit], input[type=submit]').prop('disabled', true);
Pendekatan Pemalam Alternatif
Pilihan lain ialah menggunakan pemalam jQuery di bawah, yang menggunakan fungsi data() jQuery untuk menandakan borang seperti yang dikemukakan, menghalang yang berikutnya penyerahan.
jQuery.fn.preventDoubleSubmission = function() { $(this).on('submit', function(e) { var $form = $(this); if ($form.data('submitted') === true) { e.preventDefault(); } else { $form.data('submitted', true); } }); return this; };
Penggunaan:
$('form').preventDoubleSubmission();
Tidak Termasuk Borang AJAX
Jika permohonan anda mempunyai borang AJAX yang sepatutnya membenarkan beberapa penyerahan, anda boleh mengecualikan mereka dengan menambahkan kelas, seperti yang dilihat di bawah:
$('form:not(.js-allow-double-submission)').preventDoubleSubmission();
Atas ialah kandungan terperinci Bagaimana untuk Mencegah Penyerahan Borang Berganda dalam jQuery: Teknik Apakah yang Paling Berfungsi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!