Отправка частей формы с помощью jQuery serialize() и AJAX
Я пытаюсь отправить части одной формы AJAX, используя сериализацию jQuery. Форма имеет 16 текстовых полей. У меня есть 4 кнопки. button0
отправляет текстовые поля 0,1,2,3, а button1
отправляет текстовые поля 4,5,6,7 и т.д. И т.д. Как я могу это сделать?
HTML
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Serialize</title>
<script type="text/javascript" src="jquery-1.9.1.min.js"></script>
</head>
<body>
<form id='miForm' class='miForm' name='miForm' action='env.php' method='POST'>
</form>
</body>
</html>
JQuery
$(document).ready(function(){
for(i=0;i<16;i++){
$('form').append('Campo de texto '+i+'<input type="text" id="txt'+i+'" value="Campo '+i+'" readonly="yes"/><br>');
}
for(i=0;i<4;i++){
$('form').append('<input type="button" id="butEnv'+i+'" value="Enviar'+i+'"/><br>');
}
$('form').append('<input type="button" id="butGen" value="Enviar Global"/><br>');
});
Ответы
Ответ 1
Если вы действительно хотите остаться с одной формой, попробуйте что-нибудь вроде эту скрипку.
Создайте подчасти для своей формы.
<form>
<div id="first">
<input name="tbox1" type="text">
<input name="tbox2" type="text">
<input name="tbox3" type="text">
<input id="button1" type="button" value="button1">
</div>
<div id="second">
<input name="tbox4" type="text">
<input name="tbox5" type="text">
<input name="tbox6" type="text">
<input id="button2" type="button" value="button2">
</div>
</form>
И затем просто выберите все элементы частей:
$(document).ready(function() {
$('#button1').on('click', function() {
alert($('#first input').serialize());
});
$('#button2').on('click', function() {
alert($('#second input').serialize());
});
});
Конечно, если у вас также есть поля выбора, вы должны добавить их в селектор. Например:
$('#second input, #second select').serialize()
Ответ 2
Попробуйте DEMO и CODE
Пример: измените ваши потребности:
<form name="test">
<input type="textinput" name="first" value="test1" class="form2" /> <br/>
<select name="second" class="form1">
<option value="1">opt 1</option>
<option selected="selected" value="2">opt 2</option>
</select>
<input type="textinput" name="third" value="test1" class="form2" /> <br/>
</form>
<script>
(function() {
// get second form elements
var options = $('form[name=test]').find('input, textarea, select').filter('.form2').serialize();
alert(options);
}())
</script>
Это получит все входы, которые имеют класс form2.
Ответ 3
var formData = $(form).find('#selectedOptions : input') . serialize();
$.post(url, formData) .done(function (data)
{
alert('hi');
});
where #selectedOptions is id of the element.