我正在学校做作业,我们应该模拟一个网络零售商店,通过PHP将产品从数据库发送给最终用户.然后,用户应该能够通过复选框将产品添加到购物车,然后按下将它们带到购物车的按钮,其中只显示产品表中的选定项目.
我已经取得了一些很大的进步,但我仍然坚持这个极小的问题,即:我无法弄清楚如何在表格中展示所选项目.让我告诉你我的产品表现在的样子:
和代码:
<form action="selected_products.php" method="POST">
<table>
<tr>
<th>Select</th>
<th>Product-ID</th>
<th>Product Name</th>
<th>Price SEK</th>
<tr>
<?php
// Print out all entries in a table
foreach ($rows as $value) {
extract($value);
echo "<tr><td><input type='checkbox' name='SelectedData[]' alt='Checkbox' value='$id&$name&$price'></td>";
echo "</td><td>".$id.'';
echo "</td><td>".$name.'';
echo "</td><td>".$price.'';
echo "</td></tr>";
}
?>
</table>
<br>
<input type="submit" value="Add to cart" />
</form>
Run Code Online (Sandbox Code Playgroud)
当用户选中带有复选框的产品并按下按钮时,它会将它们带到selected_products.php页面,如下所示:
和代码:
<table>
<tr>
<th>Product-ID</th>
<th>Product Name</th>
<th>Price SEK</th>
<tr>
<?php
if(!empty($_POST['SelectedData'])) {
foreach($_POST['SelectedData'] as $selected) {
echo "<tr><td>".$selected.'';
echo "</td></tr>";
}
}
?>
Run Code Online (Sandbox Code Playgroud)
所以,我的问题是:如何让所选产品填满整个表格,而不是像现在这样在一列中进行调整?我确实传递了它value='$id&$name&$price',但是如何使用此值字符串将每个条目放在selected_products.php页面上相应的列中?
正如评论中已经回答的那样,您可以使用它explode()来解决此问题.
foreach($_POST['SelectedData'] as $selected) {
list($id, $name, $price) = explode("&", $selected);
echo "<tr><td>".$id.'';
echo "</td><td>".$name.'';
echo "</td><td>".$price.'';
echo "</td></tr>";
}
Run Code Online (Sandbox Code Playgroud)
但这是一个相当糟糕的主意,因为它允许每个人用他们想要的任何东西填充它.这是因为每个人都可以发送包含他们想要的任何内容的帖子请求.更好的方法是将selected设置为项的id,然后使用项的id再次从数据库中读取所需的数据.这样,只能显示数据库中的项目.