【发布时间】:2020-07-01 22:52:41
【问题描述】:
我正在建立一个小型电子商务网站,并希望能够在某人的购物车中添加或删除商品时更新手头的库存。在我的购物车控制器中,我有四个功能:一个添加商品,一个增加商品,一个减少商品,一个删除商品。这是代码:
public function addItemToCart(Request $request, $id) {
$prevCart = $request->session()->get('cart');
$cart = new Cart($prevCart);
$product = Product::find($id);
$cart->addItem($id, $product);
$request->session()->put('cart', $cart);
return redirect()->route("home");
}
public function increaseSingleProduct(Request $request, $id) {
$prevCart = $request->session()->get('cart');
$cart = new Cart($prevCart);
$product = Product::find($id);
$cart->addItem($id, $product);
$request->session()->put('cart', $cart);
return redirect()->back();
}
public function decreaseSingleProduct(Request $request, $id) {
$prevCart = $request->session()->get('cart');
$cart = new Cart($prevCart);
if( $cart->items[$id]['quantity'] > 1) {
$product = Product::find($id);
$cart->items[$id]['quantity'] = $cart->items[$id]['quantity']-1;
$cart->items[$id]['totalSinglePrice'] = $cart->items[$id]['quantity'] * $product['price'];
$cart->updatePriceAndQunatity();
$request->session()->put('cart', $cart);
}
return redirect()->back();
}
public function deleteItemFromCart(Request $request, $id) {
$cart = Session::get('cart');
if(array_key_exists($id, $cart->items)){
unset($cart->items[$id]);
}
$prevCart = $request->session()->get("cart");
$updatedCart = new Cart($prevCart);
$updatedCart->updatePriceAndQunatity();
$request->session()->put("cart",$updatedCart);
return redirect()->route('shopping cart');
}
这里的数量不是指手头的数量,是指购物车中的数量。在产品表中,我有一个名为 stock_quantity 的列。理想情况下,这是我希望在执行每个功能时更新的内容。
【问题讨论】:
-
你有什么问题?
-
@Drewster 如何在执行每个函数时更新 stock_quantity。因此,如果有人将 1 件商品添加到购物车中,我希望在数据库中更新该库存数量。
标签: php laravel e-commerce