简体   繁体   English

输入字段名称在数组jquery中时序列化表单

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM