Как вы переопределите существующую форму 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>
Ответ 3
Там есть плагин для этого.
http://jquery.malsup.com/form/