验证并提交表单而不进入无限循环?

时间:2011-07-24 09:33:04

标签: javascript jquery html ajax submit

我使用这个jquery代码进行无限循环,我知道为什么,但我不知道如何解决这个问题:

<form id="submitme">
  <input value="" name="n1" id="n1" type="text"/>
  <input value="Send" type="button"/> 
</form>
<script>
  $('#submitme').bind( 'submit', function() {
       $.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
             if (data == "true")
                $('#submitme').submit();
       }); 
  });
</script>

3 个答案:

答案 0 :(得分:3)

jQuery.validate插件可以解决此问题,我强烈建议您使用它:

$('#submitme').validate({
    rules: {
        n1: {
            remote: {
                url: 'validate.php',
                type: 'post'
            }
        }
    }
});

但是如果你不想使用它,另一种可能性就是使用全局变量,如下所示:

$('#submitme').submit(function() {
    if (!$.formSubmitting) {
        var $form = $(this);
        $.post('validate.php', { value: $('#n1').val() }, function (data) {
            if (data == 'true') { 
                // set the global variable to true so that we don't enter
                // the infinite loop and directly submit the form
                $.formSubmitting = true;
                $form.submit();
            }
        }); 
        return false;
    }

    return true;                     
});

请注意:您放置在表单中的按钮不是提交按钮,因此单击它不会触发submit处理程序。你应该把它变成一个提交按钮:

<input value="Send" type="submit" /> 

答案 1 :(得分:0)

我不是jQuery专家,但是在Prototype中,当你为一个动作编写一个事件处理程序并且你没有停止默认动作时,它将在你完成所有回调功能之后执行。因此,只需翻转if-else语句,您就应该能够避免无限循环:

$('#submitme').bind( 'submit', function(event) {
    $.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
    if (data != "true")
        // if validation has failed, prevent default action (submit)
        event.preventDefault();
    });
    // if default action was not prevented it will be executed
})

答案 2 :(得分:0)

我找到了这个解决方案:

<form id="submitme">
  <input value="" name="n1" id="n1" type="text"/>
  <input value="Send" type="button"/> 
</form>
<script>
  $('#submitme').bind( 'submit', function() {
       if ($.data( $('#submitme' ), 'validated'))
           return true;
       $.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
             if (data == "true") {
                $.data( $('#submitme'), 'validated', true );
                $('#submitme').submit();
             }
       }); 
       return false;
  });
</script>