I checked many different questions but almost all of them was about to POST checkbox value. What I’m trying to do is to POST only the rows where the checkboxes selected.
Form contents retrived from query of 3 joined tables with AJAX from another PHP file. This is to provide live update by dropdown selection to filter results for Customers.
$sql = "SELECT * FROM z_sales_consigne AS a LEFT JOIN z_sales_price AS b ON a.SKU = b.SKU LEFT JOIN z_sales_discount AS c ON c.CustomerID = a.CustomerID WHERE a.CustomerName = '".$_POST["CustomerName"]."'";
form.php
<form name="SalesAdd" action="sls-calc.php" method="post" enctype="multipart/form-data" id="porequest"/>
<td width="30px" style="text-align:center;">
<input type="text" name="item_price[]" id="item_price" value="'.$row["price"]. '"/>
<input type="text" name="item_rate[]" id="item_rate" value="'.$row["rate"]. '"/>
<input type="text" name="item_discount[]" id="item_discount" value="'.$row["Discount"]. '"/>
<input type="checkbox" id="addProduct" name="Product[]" value="'.$row["id"]. '">
</td>
<button type="submit" name="save" id="save" class="btn btn-info" >
</form>
Posted sls-calc.php
foreach($_POST['Product'] as $key=>$check) {
echo "<tr>";
echo "<td width='120px'>".$_POST["item_price"][$key]. "</td>";
echo "<td width='400px'>".$_POST["item_rate"][$key]. "</td>";
echo "<td width='90px'>".$_POST["item_discount"][$key]. "</td>";
echo "</tr>";
}
Original form rows with selection:
When I submit; result start from the first row as much as selected checkbox amount.
But result should contain the data of selected checkboxes rows
What should I do to only get rows of selected checkboxes?
EDIT
array (size=6)
'item_price' =>
array (size=7)
0 => string '112,16' (length=6)
1 => string '112,16' (length=6)
2 => string '254,87' (length=6)
3 => string '254,87' (length=6)
4 => string '254,87' (length=6)
5 => string '254,87' (length=6)
6 => string '254,87' (length=6)
'item_rate' =>
array (size=7)
0 => string '8' (length=1)
1 => string '8' (length=1)
2 => string '8' (length=1)
3 => string '8' (length=1)
4 => string '8' (length=1)
5 => string '8' (length=1)
6 => string '8' (length=1)
'item_discount' =>
array (size=7)
0 => string '20' (length=2)
1 => string '20' (length=2)
2 => string '20' (length=2)
3 => string '20' (length=2)
4 => string '20' (length=2)
5 => string '20' (length=2)
6 => string '20' (length=2)
'productChk' =>
array (size=2)
0 => string 'on' (length=2)
1 => string 'on' (length=2)
'productId' =>
array (size=7)
0 => string '46' (length=2)
1 => string '46' (length=2)
2 => string '46' (length=2)
3 => string '46' (length=2)
4 => string '46' (length=2)
5 => string '46' (length=2)
6 => string '46' (length=2)
'save' => string '' (length=0)
3
Answers
Looks like the problem is your looping through the indexes wrong.
Currently, you’re looping through Product but the $key is the wrong variable to use
because of this, you have two items in the array with index 0 and 1, so your always going to be grabbing the first two rows like your example where you really want your $row["id"] value you set or the $check variable here.
Consider the following.
The console shows what might be passed to PHP.
This will be in PHP like so:
You can now see why if you use just the index of
$_POST['Product']
, you will get the same two elements from the other arrays.You need to pass along the ID in another field, such as a hidden field, and the look for the checked items.
Now you have a flag to check in each row.
It would benefit you to restructure your form data so that each input’s name directly references the product to which it belongs.
Consider using the following scheme to build your form:
You see now every key will include the id of the product, so when handling the form you just get the selected id’s from
$_POST['Product']
and pick out the fields you need like so: