我的表单包含隐藏的输入循环。 在我的情况下,我手动声明ajax数据中的隐藏输入而不循环。 那么如何在ajax数据中循环它们呢?
这是我的表单脚本
<form method="POST" name="myform">
<?php for($i=1;$i<=5;$i++) { ?>
<input type="hidden" name="data<?php echo $i; ?>" value="data<?php echo $i; ?>">
<?php } ?>
<input type='button' name='submitData' value='Submit' onClick='submitData();'>
</form>
这是我的Ajax脚本
function submitData() {
var form = document.myform;
$.ajax({
url: 'process.php',
type: 'post',
data: {
data1 : form["data1"].value,
data2 : form["data2"].value,
data3 : form["data3"].value,
data4 : form["data4"].value,
data5 : form["data5"].value
},
success: function (result) {
console.log(result);
},
error: function () {
console.log("error");
}
});
}
答案 0 :(得分:3)
隐藏的输入有名称和值,
使用 .serialize()
将一组表单元素编码为用于提交的字符串
data : $('form[name=myform]').serialize()
这将返回name=value
对。
如果您需要{name:value}
,请使用.each()
var formData = {}
$('form :input:hidden[name^="data"]').each(function(){
formData[this.name] = this.value;
});
在ajax中,
data : formData ,
<强> Demo 强>
答案 1 :(得分:2)
如果您要发布整个表单,可以在请求中直接使用jQuery&#39; .serialize():
$.ajax({
url: 'process.php',
type: 'post',
data: $('#myform').serialize(),
...
答案 2 :(得分:1)
另外,一个好方法是将字符串转换为JSON对象,并在PHP中转换数组中的字符串:
var dataJSON = JSON.stringify({..Your form obj...});
$.ajax({
url: 'process.php',
type: 'post',
data: dataJSON,
success: function (result) {
console.log(result);
},
error: function () {
console.log("error");
}
});
<强> process.php 强>
$data = json_decode($_POST["data"]);
print_r($data);