[英]serialize form while input fields name are in array jquery
I have a form in which input are like 我有一个输入像
<input type="text" value="" name="fieldval[3][4][]" >
now when i serialize this form using jquery i am getting result like this 现在,当我使用jQuery序列化此表单时,我得到这样的结果
app_id=1&app_id=2&app_id=3&fieldval%5B2%5D%5B2%5D%5B%5D=1&fieldval%5B2%5D%5B2%5D%5B%5D=day&fieldval%5B3%5D%5B4%5D%5B%5D=23&fieldval%5B1%5D%5B1%5D%5B%5D=1&fieldval%5B1%5D%5B1%5D%5B%5D=mb&fieldval%5B1%5D%5B3%5D%5B%5D=200&fieldval%5B1%5D%5B3%5D%5B%5D=mb
please tell me the right way how to get values in proper way from this type input field. 请告诉我正确的方法,如何从此类型输入字段中以正确的方式获取值。
now when I use serializeArray i get array like 现在当我使用serializeArray我得到像
Array
(
[step_number] => 4
[app_id] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
[formdata] => Array
(
[0] => Array
(
[name] => app_id[]
[value] => 1
)
[1] => Array
(
[name] => app_id[]
[value] => 2
)
[2] => Array
(
[name] => app_id[]
[value] => 3
)
[3] => Array
(
[name] => fieldval[2][2][]
[value] => 1
)
[4] => Array
(
[name] => fieldval[2][2][]
[value] => day
)
[5] => Array
(
[name] => fieldval[3][4][]
[value] => 23
)
[6] => Array
(
[name] => fieldval[1][1][]
[value] => 1
)
[7] => Array
(
[name] => fieldval[1][1][]
[value] => mb
)
[8] => Array
(
[name] => fieldval[1][3][]
[value] => 200
)
[9] => Array
(
[name] => fieldval[1][3][]
[value] => mb
)
[10] => Array
(
[name] => plan_type
[value] => free
)
[11] => Array
(
[name] => price
[value] =>
)
[12] => Array
(
[name] => sell_type
[value] => up
)
)
)
Now i want to change this array format to like this 现在我想更改此数组格式为这样
Array
( [app_id] => Array ( [0] => 1 [1] => 2 [2] => 3 ) ([app_id] =>数组([0] => 1 [1] => 2 [2] => 3)
[fieldval] => Array
(
[2] => Array
(
[2] => Array
(
[0] => 1
[1] => day
)
)
[3] => Array
(
[4] => Array
(
[0] => 23
)
)
[1] => Array
(
[1] => Array
(
[0] => 1
[1] => mb
)
[3] => Array
(
[0] => 200
[1] => mb
)
)
)
[plan_type] => free
[price] =>
[sell_type] => up
) )
how can i do this 我怎样才能做到这一点
Use a form tag with id like this. 使用具有此类ID的表单标签。
<form id="my-form-name" method="POST" action="http://something.com/">
<!-- Your fields here-->
<input type="text" value="" name="fieldval[]" />
<input type="text" value="" name="fieldval[]" />
</form>
In your JS 在你的JS里
var data =$("#my-form-name").serializeArray();
console.log(data);
Now you have an array with your inputs data. 现在,您有了一个包含输入数据的数组。
Here is full example 这是完整的例子
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.0/jquery.min.js"></script>
<form id="frm">
<input type="text" value="3" name="fieldval[1][4][]" >
<input type="text" value="43" name="fieldval[2][4][]" >
<input type="text" value="22" name="fieldval[3][4][]" >
<input type="text" value="65" name="fieldval[4][4][]" >
<input type="button" value="click" id="click">
</form>
<div id="results"></div>
<script>
$(document).ready(function(){
$("#click").click(function(){
var data =$("#frm").serializeArray();
var fields = $( ":input" ).serializeArray();
jQuery.each( fields, function( i, field ) {
$( "#results" ).append( field.value + " " );
});
});
});
</script>
I hope this will help 我希望这个能帮上忙
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.