Php 将数量添加到篮子项目就是添加新项目

Php 将数量添加到篮子项目就是添加新项目,php,session,session-variables,Php,Session,Session Variables,我正在创建一个篮子,我想要的是,如果篮子中已经存在的项目再次添加,则原始项目的数量将附加1 相反,当我添加一个已经在购物篮中的商品时,会添加一个新商品,并且可以通过单击原始商品上的+1来追加这个新商品的数量 basket.php <?php foreach ($_SESSION["basket"] as $basketItemArray) { ?> <form role="form" action="includes/function

我正在创建一个篮子,我想要的是,如果篮子中已经存在的项目再次添加,则原始项目的数量将附加1

相反,当我添加一个已经在购物篮中的商品时,会添加一个新商品,并且可以通过单击原始商品上的+1来追加这个新商品的数量

basket.php

<?php
  foreach ($_SESSION["basket"] as $basketItemArray) {                   
?>

<form role="form" action="includes/functions/create_shopping_cart.php" method="post">
    <button type="submit" name="basket-button" class="btn btn-default" value="<?php echo $basketItemArray["item_id"]; ?>"><i class="fa fa-plus" aria-hidden="true"></i></button>
    <? echo $basketItemArray["quantity"]; ?>
    <button class="btn btn-default"><i class="fa fa-minus" aria-hidden="true"></i></button>
</form>
$product_id = $_POST['basket-button'];
$sql = "SELECT * FROM menu WHERE product_id='".$product_id."'";

$result = $connection->query($sql);
$row = $result->fetch_assoc();

if (empty($_SESSION["basket"])) {
    $_SESSION["basket"]  = array( 

    array( "item_id"=>$row['product_id'], "item_name"=>$row['name'],"quantity"=>1 , "price"=>$row['price']) );

} else {
    // There is already a basket to append to
    $current_basket = $_SESSION["basket"];

    $found = false;
    foreach($_SESSION['basket'] as $product)
    {
        if($product_id == $product['item_id']) {
            $found = true;
            break;
        }
    }

    if($found)
    {
        $_SESSION['basket'][$product_id]['quantity'] ++;               
    } else {
        $new_basket  = array( 

        array( "item_id"=>$row['product_id'], "item_name"=>$row['name'],"quantity"=>1 , "price"=>$row['price']) );

        $_SESSION['basket'] = array_merge($current_basket, $new_basket);      
    } 
}
结果

您没有针对/使用篮子中产品的索引。 试试这个:

$product_id = $_POST['basket-button'];
$sql = "SELECT * FROM menu WHERE product_id='".$product_id."'";

$result = $connection->query($sql);
$row = $result->fetch_assoc();

if (empty($_SESSION["basket"])) {
    $_SESSION["basket"]  = array( 

    array( "item_id"=>$row['product_id'], "item_name"=>$row['name'],"quantity"=>1 , "price"=>$row['price']) );

} else {
    // There is already a basket to append to
    $current_basket = $_SESSION["basket"];

    $found = false;
    $id = '';
    foreach($_SESSION['basket'] as $key=>$product)
    {
        if($product_id == $product['item_id']) {
            $found = true;
            $id    = $key;
            break;
        }
    }

    if($found)
    {
        $_SESSION['basket'][$id]['quantity']++;               
    } else {
        $new_basket  = array( 

        array( "item_id"=>$row['product_id'], "item_name"=>$row['name'],"quantity"=>1 , "price"=>$row['price']) );

        $_SESSION['basket'] = array_merge($current_basket, $new_basket);      
    } 
}

您的代码可以进一步优化,但现在更重要的是让它正常工作。

您是否检查了
$found
是否设置为
true
?是,当我尝试此操作时,$found设置为true当您在++之前删除空格时会发生什么情况?当$found为true时,您是否也检查了执行if循环的正确部分?是的,执行了正确的部分。谢谢您的帮助,但我必须做的唯一调整是在向篮子添加数量时,唯一需要的参数是[$id]-[$product\U id]停止工作。好的,我在代码中更改了它。处理整个系统并摆脱
foreach
的更好方法是使用product\U id作为篮子索引。这样,您可以通过检查
if(isset$\u SESSION['basket'][$product\U id]来直接瞄准它)
您不使用“数组合并”,而是使用“$”会话['basket'][$product\u id]=$new\u basket”