1

これは完全に間違っていると思いますが、ショッピングカートに追加されたときにアイテムの値をテーブルに表示しようとしています。私のコードは次のようになります。

<?php
function minicart() {
    foreach($_SESSION as $name => $value) {
        if ($value > 0) {
            if (substr($name, 0, 5)=='cart_') {
                $id = substr($name, 5, (strlen($name) -5));
                $get = mysql_query('SELECT id, name, price FROM products WHERE id='.mysql_real_escape_string((int)$id));
                while ($get_row = mysql_fetch_assoc($get)) {
                    $sub = $get_row['price']*$value;
                    '<table border = "1">'
                    '<tr>'
                    '<td>'<echo $get_row['name'].' x '.$value.' @ &pound;'.number_format($get_row['price'], 2).' = &pound;'.number_format($sub, 2).' <a href="minicart.php?remove='.$id.'">[-]</a> <a href="minicart.php?add='.$id.'">[+]</a> <a href="minicart.php?delete='.$id.'">[Delete]</a><br />''</tr>';
                    '</tr>'
                    '</table>'
                }
            }
            $total += $sub;
        }
    }
    if ($total==0) {
        echo "Your cart is empty";
    }
    else {
        echo '<br />Total: &pound;'.number_format($total, 2);

    ?>
4

3 に答える 3

0

テーブルを正しい形式に書き直そうとしました:

echo '<table border = "1">';
while ($get_row = mysql_fetch_assoc($get)) {
    $sub = $get_row['price']*$value;
    echo '
    <tr>
    <td>'.
    $get_row['name'].' x '.$value.' @ &pound;'.number_format($get_row['price'], 2).' = &pound;'.number_format($sub, 2).'
    <a href="minicart.php?remove='.$id.'">[-]</a> 
    <a href="minicart.php?add='.$id.'">[+]</a> 
    <a href="minicart.php?delete='.$id.'">[Delete]</a><br />
    </td>
    </tr>
    ';
}
echo '</table>';

PHP文字列を参照してください

于 2013-03-17T16:55:23.070 に答える
0

ifステートメントを次のように置き換えたいと思います。

これにより、おそらく探しているアイテムごとに1行のテーブルが1つ作成されます。

        if (substr($name, 0, 5)=='cart_') {
            $id = substr($name, 5, (strlen($name) -5));
            $get = mysql_query('SELECT id, name, price FROM products WHERE  id='.mysql_real_escape_string((int)$id));
            echo '<table border = "1">';
            echo '<tr>';
            while ($get_row = mysql_fetch_assoc($get)) {
                $sub = $get_row['price']*$value;                    
                echo '<td>';
                echo $get_row['name'].' x '.$value.' @ &pound';
                echo number_format($get_row['price'], 2).' = &pound';
                echo number_format($sub, 2);
                echo '<a href="minicart.php?remove='.$id.'">[-]</a> ';
                echo '<a href="minicart.php?add='.$id.'">[+]</a> ';
                echo '<a href="minicart.php?delete='.$id.'">[Delete]</a><br />';
            }
            echo'</tr>';
            echo'</table>';
        }
于 2013-03-17T16:57:00.867 に答える
0

これを試して:

function minicart()
{
    $items = 0;
    $tbl = array();
    foreach($_SESSION as $name => $value)
    {
        if ($value > 0) {
            if (substr($name, 0, 5)=='cart_')
            {
                $id = substr($name, 5, (strlen($name) -5));
                $get = mysql_query('SELECT id, name, price FROM products WHERE id='.mysql_real_escape_string((int)$id));
                $tbl[] = '<table border="1"><thead><tr>'
                  . '<th>Item</th>'
                  . '<th>Quantity</th>'
                  . '<th>Unit Price</th>'
                  . '<th>SubTotal</th>'
                  . '<th>Action</th>'
                  . '</tr></thead><tbody>'
                ;
                while ($get_row = mysql_fetch_assoc($get)) {
                    $items++;
                    $sub = $get_row['price'] * $value;
                    $tbl[] = '<tr>'
                      . '<td>' . $get_row['name'] . '</td>'
                      . '<td>' . $value . '</td>'
                      . '<td>&pound;' . number_format( $get_row['price'], 2 ) . '</td>'
                      . '<td>$pound;' . number_format( $sub, 2) . '</td>'
                      . '<td>'
                      . ' <a href="minicart.php?remove=' . $id . '">[-]</a> '
                      . ' <a href="minicart.php?add=' . $id . '">[+]</a> '
                      . ' <a href="minicart.php?delete=' . $id . '">[Delete]</a>'
                      . '</td>'
                      . '</tr>'
                    ;
                }
                $tbl[] = '</tbody>';
            }
            $total += $sub;
        }
    }
    if ($items==0)
    {
        echo "Your cart is empty";
    }
    else
    {
        $tbl[] = '<tfoot><tr>'
               . '<td colspan="3" style="text-align:right; font-weight:bold">Total:</td>'
               . '<td>&pound;' . number_format($total, 2) . '</td></tr></tfoot></table>';
        echo implode( "\n", $tbl );

    }
}

ロジックを変更して、商品数が 0 の場合に「カートが空です」というメッセージを表示し、商品のコストがゼロになるようにしました。

于 2013-03-17T17:13:31.753 に答える