微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 如果ajax验证器使用jquery返回true,则提交表单

我不知道我哪里出错了.这个想法是在提交表单之前,其中一个输入字段通过ajax发送到服务器端验证器.如果响应为1,则输入有效并且应提交表单.如果响应为0,则不应提交表单.问题是我无法弄清楚如何在ajax请求函数中设置一个阻止表单提交的变量.这就是我所拥有的:

$("#form").submit(function() {
    var valid= false;
    var input = $("#input").val();
    $.ajax({
       type: "POST",
       url: "validator.PHP",
       data: "input=" + input,
       success: function(msg){
            valid = (msg == 1) ? true : false;
            if(!valid) {
                $("#valid_input").html("Please enter valid info");
            } else {
                $("#valid_input").html("");
            }
       }
     });
    return valid;
 });

解决方法:

问题是$.ajax请求是异步的,需要一段时间才能完成.因此,在成功函数执行事件之前,函数继续并返回false.

解决此问题,您可以为AJAX调用的设置添加async:false,但这会暂停执行,直到AJAX调用返回.

另一种解决方案是以名为valid的形式创建隐藏输入:

<input type="hidden" name="valid" value="false" />

然后在提交函数内但在ajax调用之前创建对from var $form = $(this)的引用.然后,如果AJAX调用返回有效,则更改此隐藏输入的值,然后再次提交表单:

$('input[name="valid"]').val('true');
$form.submit();

然后在submit函数结束时,如果隐藏输入的值为true,则仅返回false:

if ($('input[name="valid"]').val() == 'false') {
    $.ajax({ ... }); // changes the value of the hidden input from false to true
    return false;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐