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

我使用这个 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>

解决方法

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;                     
});

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

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

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...