4

I have a simple AJAX form that works as it should when I submit it. However, if I then enter new data into the same form (without refreshing the page), then it submits the form twice. If I do this a third time, then it submits the form three time, and so on. Why is it doing this? Here is my code:

$(document).ready(function(){
    $("#myForm").submit(function() {
        var myField = $('#myID).val();
        $.ajax({
            type: "POST",
            url: 'myFile.php',
            dataType: 'html',
            data: {myData:myField},
            success: function(data){
                alert(data);
            }
        });

        return false;
    });
});
BartoszKP
  • 34,786
  • 15
  • 102
  • 130
Nancy Collier
  • 1,469
  • 4
  • 17
  • 21

3 Answers3

11

Even I got stuck with the same problem while developing a AJAX login form. After an googling for couple of hours I found a solution. I hope this should help you out.

Basically you have to unbind the current instance of form's submit action after your ajax request gets completed. So add this line before return false;

$("#myform").unbind('submit');

Therefore your entire code should look like



    $(document).ready(function(){
        $("#myForm").submit(function() {
            var myField = $('#myID).val();
            $.ajax({
                type: "POST",
                url: 'myFile.php',
                dataType: 'html',
                data: {myData:myField},
                success: function(data){
                    alert(data);
                }
            });

            /* Add this line */
            $("#myform").unbind('submit');
            return false;
        });
    });


Saurabh Mishra
  • 1,511
  • 1
  • 11
  • 7
1

I had the same problem.

I found the solution in: jquery : submitting a form twice

Basicaly is adding .submit() to Saurabh Mishra answer:

$('#form1').unbind('submit').submit();
Community
  • 1
  • 1
dvsaraiva
  • 491
  • 1
  • 6
  • 13
0

Unbinding the form can break you Ajax from. I found that as long as I declare the form first.

$('#my_form').ajaxForm

that all works as expected, and follows the standard protocol. I just spent a day chasing the 'missing template' error on the form submission because I unbound the form.

bobbdelsol
  • 996
  • 6
  • 21