0

我正在使用 validationEngine jQuery 插件来验证我的网络表单。验证完成后,我想通过 ajax 提交表单。表单提交很好,没有附加验证引擎插件。验证有效,但 ajax 在完成后不会触发提交表单。我究竟做错了什么:

jQuery("form#sign-up").validationEngine({
    onValidationComplete: function () {
        var first = $("input#first").val();
        var last = $("input#last").val();
        var email = $("input#email").val();
        var pass = $("input#pass").val();



        var dataString = 'first=' + first + '&last=' + last + '&email=' + email + '&pass=' + pass;

        //to send the ajax request  
        $.ajax({
            type: "POST",
            url: "./register.php",
            data: dataString,
            success: function () {
                $('#sign-up').html("<div id='message'></div>");
                $('#message').html("<h2>Thanks!</h2>")
                    .append("<p>We'll send you an email when infoFree is ready to Rock n' Roll.</p>")
                    .hide()
                    .fadeIn(500, function () {
                    $('#message').append("<img id='checkmark' src='./assets/images/check.png' />");
                });
            }
        });
    }
});
4

1 回答 1

0

验证引擎阻止表单实际提交,因此不要在 onValidationComplete 中做所有事情,只需将其全部移动到表单提交时的函数中:

$(document).ready(function() {
  $("form#sign-up").validationEngine();
  $("form#sign-up").submit(function(){
    var first = $("input#first").val();
    var last = $("input#last").val();
    var email = $("input#email").val();
    var pass = $("input#pass").val();

    var dataString = 'first='+ first + '&last=' + last + '&email=' + email + '&pass=' + pass;

    //to send the ajax request  
    $.ajax({
      type: "POST",
      url: "./register.php",
      data: dataString,
      success: function() {
        $('#sign-up').html("<div id='message'></div>");
        $('#message').html("<h2>Thanks!</h2>")
        .append("<p>We'll send you an email when infoFree is ready to Rock n' Roll.</p>")
        .hide()
        .fadeIn(500, function() {
          $('#message').append("<img id='checkmark' src='./assets/images/check.png' />");
        });
      } 
    });
  });
}); // ready

~西里克斯

于 2011-08-12T14:49:02.760 回答