Как вы переопределите существующую форму html для использования jquery для отправки формы?

У меня есть простая форма, которую я сейчас отправляю на сервер для обновления псевдонима. Какой код jquery я могу добавить (без изменения формы), чтобы страница не обновлялась, а вместо jQuery будет выставлять форму в фоновом режиме, а затем всплывать предупреждающее сообщение, содержащее ответ с сервера?

<form method="post" action="http://www.myserver.com/update_nickname" name="input">
    Quick form to test update_nickname:<br>
    New nickname:<input type="text" value="BigJoe" name="newNickname"><br>
    <input type="submit" value="Submit">
</form>

<script src="jquery-1.4.2.min.js" type="text/javascript"> </script>

Ответ 1

попробуйте прочитать это.

или

$("form").submit(function(e){
    var form = $(this);
    $.ajax({ 
         url   : form.attr('action'),
         type  : form.attr('method'),
         data  : form.serialize(), // data to be submitted
         success: function(response){
            alert(response); // do what you like with the response
         }
    });
    return false;
 });

Ответ 2

Вам нужно использовать jQuery для привязки к событию "отправить" и предотвратить действие по умолчанию. Было бы немного более эффективно, если бы ваша форма и псевдоним использовали id в дополнение к их именам:

<script type="text/javascript">
    jQuery(function($){
      $("form[name=input]").submit(function(e){
        e.preventDefault(); // Keep the form from submitting
        var form = $(this);

        // Use the POST method to post to the same url as
        // the real form, passing in newNickname as the only 
        // data content
        $.post( form.attr('action'), { newNickname: form.find(':text').val() }, function(data){
          alert(data); // Alert the return from the server
        }, "text" );
      });
    });
</script>