使用jquery事件提交表单的无限循环

gre*_*ner 14 jquery form-submit

当我尝试捕获表单提交时,代码陷入循环.目的是在表单出来之前替换表单的值.

$('form').submit(function(e){
   e.preventDefault();
   $.ajax({
      type: "POST",
      url: 'convert.asp',
      data: $('form').serialize(),
      success: function(response){
         $('input[name="field1"]').val(response);
         $('form').submit();
      }
   });
   return false;
});
Run Code Online (Sandbox Code Playgroud)

有没有人有任何想法?

更新:我最初将它绑定到按钮单击事件并且它正在工作,但我想保留提交按钮的[enter]键元素.看到代码有点不合逻辑,抓住按键会更好吗?

Rob*_*ann 46

我假设您的ajax是在最终提交之前验证表单的尝试.在这种情况下,只需在提交表单之前取消绑定验证功能.

  success: function(response){
     $('input[name="field1"]').val(response);
     // Add unbind to remove validations
     $('form').unbind().submit(); 
  }
Run Code Online (Sandbox Code Playgroud)

  • 从jQuery 1.7开始,和.off()方法比.unbind()更受欢迎 (3认同)
  • @bart $('form').off().submit(); (2认同)

gdo*_*ica 6

在成功中,您触发另一个提交...

$('form').submit(function(e){
   e.preventDefault(); // redundant,  you return false in the end. <<<===
   $.ajax({
      type: "POST",
      url: 'convert.asp',
      data: $('form').serialize(),
      success: function(response){
         $('input[name="field1"]').val(response);
         $('form').submit(); // <=== delete this! <<<<=================
      }
   });
   return false;
});
Run Code Online (Sandbox Code Playgroud)