Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mencegah Penyerahan Borang Berganda dalam jQuery: Teknik Apakah yang Paling Berfungsi?

Bagaimana untuk Mencegah Penyerahan Borang Berganda dalam jQuery: Teknik Apakah yang Paling Berfungsi?

DDD
DDDasal
2024-11-09 15:07:02235semak imbas

How to Prevent Double Form Submissions in jQuery: What Techniques Work Best?

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!

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