在另一个PHP页面中将变量从一个表传递到另一个表

tob*_*os1 10 html php mysql

我正在学校做作业,我们应该模拟一个网络零售商店,通过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页面上相应的列中?

Chr*_*ann 5

正如评论中已经回答的那样,您可以使用它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再次从数据库中读取所需的数据.这样,只能显示数据库中的项目.