使用jquery ajax post提交表单输入数组

时间:2013-01-23 07:42:19

标签: php jquery ajax input multidimensional-array

好吧我想通过jquery ajax提交表单。所有输入都在一个数组中,它是多维的。

它是一个动态表单,它使用数组键作为问题ID。 该子项用于在问题集中对问题进行分组。

<form name="testing" id="testing" method="post">
    <label>Question 1?</label> 
    <input type="text" name="data[14][1]" id="" class="" value=""><br>
    <label>Question 2?</label> 
    <input type="text" name="data[16][1]" id="" class="" value=""><br>
    <label>Question 1?</label> 
    <input type="text" name="data[14][2]" id="" class="" value=""><br>
    <label>Question 2?</label> 
    <input type="text" name="data[16][2]" id="" class="" value=""><br>
    <label>Question 3?</label> 
    <select name="data[19]" id="" class="">
        <option value="1">1</option>
        <option value="2">2</option>
        <option value="3">3</option>
        <option value="4">4</option>
    </select><br>
    <input type="submit" value="Submit">
</form>

这就是我的示例html。这是我的示例jquery:

$("#testing").submit(function() { 
           var data = $('input[name^="data\\["]').serializeArray();
                $.ajax({ 
                 type: "POST",
                 url:  "upload.php",
                 data: {internalform: "submit", data: data},
                 dataType : "text",

           success: function(returndata){
            if(returndata == "no") 
             { return false;
             } else {
               alert("clicked 1 " + returndata);
                }
                 } 
                 });    
            return false;
            }); 

问题是我将其作为返回数组:

Array
(
    [0] => Array
        (
            [name] => data[14]
            [value] => sd
        )

    [1] => Array
        (
            [name] => data[16]
            [value] => s
        )

)

但我想要一个像这样的数组:

Array ( [14] => ddd [16] => ddd [19] => 4 ) 

我确定它很简单,但我错过了一些东西。我知道它为什么这样做,但我无法按照我想要/需要的方式得到它。有人可以帮忙吗?

4 个答案:

答案 0 :(得分:3)

尝试下面的代码片段,我没有对此进行测试,但可能它应该可以使用。

var data = $('input[name^="data\\["]').serializeArray();部分替换为以下代码段

var data = {};
$.each($('input[name^="data\\["]')​.serializeArray()​, function() {
    data[this.name] = this.value;
})​;

尝试这一点,它将解决前面问题中的数据

我已经解决了这个问题

var data = {};
$.each($('select[name^="data\\["] , input[name^="data\\["]').serializeArray(), function() {
   var vv = this.name.replace(/data/, '' ).replace(/(\[[0-9]\])$/,'');
   data[vv] = this.value;           
});

答案 1 :(得分:0)

我不知道如何在jquery中执行此操作,但您可以在php中转换该数组

$result = array();
foreach($array as $item) {
   $index = intval(preg_replace("/data\[([0-9]*)\]/", '\1' $item['name']));
   $result[$index] = $item['value'];
}

答案 2 :(得分:0)

试试这个

var data = {}; 
$('input[name^="data\\["]').serializeArray().map(function(n){
    var name = n['name'].replace(/data\[([0-9]*)\]\[(.*)\]/, '$1');
    data[name] = n['value'];
});

答案 3 :(得分:0)

var data = {};
$.each($('input[name^="data\\["]')​.serializeArray()​, function() {
    data[this.name] = this.value;
})​;

给出控制台错误&gt;&gt;

  参数列表

之后的

Uncaught SyntaxError:missing)