我的表格看起来像那样:
<form method="POST">
<p>Model 1</p>
<input name="data_quantity[]">
<input name="data_consignment[]">
<input name="data_price[]">
<p>Model 2</p>
<input name="data_quantity[]">
<input name="data_consignment[]">
<input name="data_price[]">
<p>Model 3</p>
<input name="data_quantity[]">
<input name="data_consignment[]">
<input name="data_price[]">
...
</form>
现在。当我读取PHP上的数据时,我在POST数组中有三个数组($_POST
):$_POST['data_quantity'], $_POST['data_consignment'], $_POST['data_price']
...
我需要将它们合并在一起,所以我计算一个数组中的总数,然后我做for
并重新创建数组,并在帖子中的每个数组中使用值。快速举例:
public function build_Lineitems($Quantity=array(), $Consignment=array(), $TransferFrom=array(), $TransferTo=array(), $Price=array(), $Attributes=array()){
...
# On va boucler sur un des 6 tableaux...
$Lineitems = array();
foreach($Quantity as $ModelID => $Lineitem){
# Entrée dans le tableau
if(isset($Lineitems[$ModelID]) === FALSE){
$Lineitems[$ModelID] = array();
}
# Est-ce que c'est un tableau
if(is_array($Lineitem) === TRUE){
foreach($Lineitem as $Entry => $Clone){
$Lineitems[$ModelID][] = array(
'qty' => (isset($Quantity[$ModelID][$Entry]) === TRUE ? $Quantity[$ModelID][$Entry] : array()),
'con' => (isset($Consignment[$ModelID][$Entry]) === TRUE ? $Consignment[$ModelID][$Entry] : array()),
'xferfrom' => (isset($TransferFrom[$ModelID][$Entry]) === TRUE ? $TransferFrom[$ModelID][$Entry] : array()),
'xferto' => (isset($TransferTo[$ModelID][$Entry]) === TRUE ? $TransferTo[$ModelID][$Entry] : array()),
'price' => (isset($Price[$ModelID][$Entry]) === TRUE ? $Price[$ModelID][$Entry] : array()),
'attr' => (isset($Attributes[$ModelID][$Entry]) === TRUE ? (empty($Attributes[$ModelID][$Entry]) === FALSE ? explode(',', $Attributes[$ModelID][$Entry]) : array()) : array())
);
}
} else {
# Okay
$Lineitems[$ModelID] = array(
'qty' => (isset($Quantity[$ModelID]) === TRUE ? $Quantity[$ModelID] : array()),
'con' => (isset($Consignment[$ModelID]) === TRUE ? $Consignment[$ModelID] : array()),
'xferfrom' => (isset($TransferFrom[$ModelID]) === TRUE ? $TransferFrom[$ModelID] : array()),
'xferto' => (isset($TransferTo[$ModelID]) === TRUE ? $TransferTo[$ModelID] : array()),
'price' => (isset($Price[$ModelID]) === TRUE ? $Price[$ModelID] : array()),
'attr' => array()
);
}
}
# On renvoie
return $Lineitems;
}
我的问题是,有更清洁的方法吗?谢谢。 (这:多个数组的合并部分。
答案 0 :(得分:1)
您可以首先发布多维值:
<input name="data[quantity][]">
或者采用不同的等级顺序(在计算$i
时):
<input name="data[<?php echo $i; ?>][quantity]">
答案 1 :(得分:0)
您是否考虑过将array_merge或其递归兄弟合并在一起的所有内容? 虽然你应该小心不要直接在$ _POST上使用它来获取不需要的数据