Как переопределить существующую HTML-форму, чтобы использовать JQuery для публикации формы? - PullRequest
12 голосов
/ 03 июня 2010

У меня есть простая форма, которую я сейчас отправляю на сервер, чтобы обновить ник. Какой код 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>

Ответы [ 3 ]

25 голосов
/ 03 июня 2010

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

или

$("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;
 });
5 голосов
/ 03 июня 2010

Вам необходимо использовать jQuery для привязки к событию submit и предотвращения действия по умолчанию. Было бы немного эффективнее, если бы ваша форма и никнейм использовали 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>
1 голос
/ 03 июня 2010

Для этого есть плагин.

http://jquery.malsup.com/form/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...