Jquery在提交时不循环

Jquery on submit without looping

本文关键字:循环 提交 Jquery      更新时间:2023-09-26

我正在制作一个事件,其中页面检查是否需要通过POST提交数据,或者简单的ajax调用是否可以。IE:有一个文件,它需要处理上传,如果没有文件,提交数据并继续使用页面。

$(document).on("submit", "form", function (e) { 
     e.preventDefault();
     if($(this).find('[name=file]').val()) { // HAS FILE SUBMIT
          /*
              If I use $(this).submit() then it just loops.  I figured return true might work or putting e.preventDefault(); after this code
          */
     }

     // If it made it past that if then does ajax things that are fine.
}

提前感谢。

使用jQuery的$(this).submit()将触发事件处理程序,并阻止默认操作,所以表单永远不会提交,它只是循环。

要防止这种情况发生,请使用本机this.submit()

$(document).on("submit", "form", function (e) { 
    e.preventDefault();
    if ($(this).find('[name=file]').val()) { // HAS FILE SUBMIT
         this.submit();
    } else {
         $.ajax(options); // ...etc
    }
}

我没有测试它,但你不能先测试文件,然后,如果没有文件,做一个防止默认(或返回false)?

$(document).on("submit", "form", function (e) { 
     if($(this).find('[name=file]').val()) {
        return true;
     }
     else {
         e.preventDefault();
         // Do AJAX 
     }
}