首页 >web前端 >js教程 >如何在不禁用表单元素的情况下防止 jQuery 中的双重表单提交?

如何在不禁用表单元素的情况下防止 jQuery 中的双重表单提交?

Patricia Arquette
Patricia Arquette原创
2024-11-08 16:51:02731浏览

How to Prevent Double Form Submissions in jQuery Without Disabling Form Elements?

使用 jQuery 防止表单中的双重提交

用户经常会意外地重新提交表单,尤其是当他们需要很长时间来处理时。为了防止这种情况,可以使用 jQuery 在初次尝试后禁用表单提交。但是,在某些情况下,禁用所有表单元素(包括输入)可能会无意中阻止提交本身。

使用 jQuery 插件改进的解决方案

另一种方法是使用一个用于处理双重提交预防的 jQuery 插件。该插件利用 jQuery 的 data() 方法将表单标记为已提交或未提交。

jQuery.fn.preventDoubleSubmission = function() {
  $(this).on('submit', function(e) {
    var $form = $(this);

    if ($form.data('submitted') === true) {
      // Previously submitted - don't submit again
      e.preventDefault();
    } else {
      // Mark it so that the next submit can be ignored
      $form.data('submitted', true);
    }
  });

  // Keep chainability
  return this;
};

用法

要使用此插件,只需将其包含在 $(' form').preventDoubleSubmission();.

排除允许的 AJAX表单

如果应允许某些表单(例如 AJAX 表单)提交多次,则可以使用 CSS 类排除它们,如以下示例所示:

$('form:not(.js-allow-double-submission)').preventDoubleSubmission();

通过这种方式,可以毫无问题地提交表单,同时有效防止意外重新提交,增强用户体验并防止潜在的数据丢失。

以上是如何在不禁用表单元素的情况下防止 jQuery 中的双重表单提交?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn