I have a simple ajax call from a form submit. It works when I debug, i.e the alert pops up but when running it, it doesn't work?
This seems a bit mysterious to me.
$(function(){
    $("#signUpForm").submit(function(){
        var request = $.ajax({
            url:"php/newUser.php",
            type:"POST"
        });
        request.done(function(msg){
            alert(msg);
        });
    });
});
If you run an ajax call on the .submit() handler of a form, the Ajax request will fire but then the form will continue submitting, thus refreshing the page and never firing your callback function.
Instead, you should call event.preventDefault() at the end of the submit handler function to prevent the browser from submitting the form normally with a new HTTP request. To do this you'll need to add event as a parameter to the callback function, like this:
$( "#target" ).submit(function( event ) {
  alert( "Handler for .submit() called." );
  event.preventDefault();
});
The reason it works when you debug is because everything happens slowly as you step through, without the browser submitting the form.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With