好吧我想通过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 )
我确定它很简单,但我错过了一些东西。我知道它为什么这样做,但我无法按照我想要/需要的方式得到它。有人可以帮忙吗?
答案 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)