request->userId; if (!$userId) return []; $where=[ 'uid'=>$userId, 'is_pay'=>0 ]; $list = Cart::where($this->searchWhere)->where($where) ->limit($this->limitOffset, $this->limitLength) ->order(['id' => 'desc']) ->select()->each(function ($item) { return $item; }) ->toArray(); foreach ($list as $key => &$item) { $find = StoreBranchProduct::where(['store_id'=>$item['store_id'],'product_id'=>$item['product_id']]) ->field('product_id,image,price,store_name,unit') ->find(); if($find){ $item['goods_total_price'] = bcmul($item['cart_num'], $find['price'], 2); $this->total_price=bcadd($this->total_price,$item['goods_total_price'],2); $item['imgs'] = $find['image']; $item['sell'] = $find['price']; $item['goods_name'] = $find['store_name']; $item['unit_name'] = StoreProductUnit::where('id',$find['unit'])->value('name'); } } return $list; } /** * @notes 购物车数量 * @return int * @date 2024/04/27 11:26 */ public function count(): int { $userId = $this->request->userId; if (!$userId) return 0; $where=[ 'uid'=>$userId, 'is_pay'=>0 ]; return Cart::where($this->searchWhere)->where($where)->count(); } public function extend() { return ['total_price'=>$this->total_price]; } }