国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > PHP > 正文

基于CI(CodeIgniter)框架實(shí)現(xiàn)購(gòu)物車功能的方法

2024-05-05 00:03:09
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例講述了基于CI(CodeIgniter)框架實(shí)現(xiàn)購(gòu)物車功能的方法。分享給大家供大家參考,具體如下:

在商城項(xiàng)目中,購(gòu)物車是非常重要的一環(huán),此處留下源碼,留作筆記!!!

話不多說(shuō),往下看:

1. 源代碼

<?phpdefined('BASEPATH') OR exit('No direct script access allowed');class cart extends Home_Controller {  private $info = array();    #前臺(tái)提交數(shù)據(jù)  private $specData = array();  #規(guī)格信息  private $prodData = array();  #貨品組合信息  private $cartData = array();  #購(gòu)物車入庫(kù)數(shù)據(jù)  /**   * 構(gòu)造函數(shù)   */  public function __construct()  {    parent::__construct();    $this->load->model('goodsModel','goods');    $this->load->model('productModel','product');    $this->load->model('goodsAttrModel','goodsAttr');  }  /**   * [購(gòu)物車]數(shù)據(jù)添加   */  public function cartAdd()  {    #接收購(gòu)物車提交數(shù)據(jù)    $this->info = $this->input->post();  // $this->ajaxReturn($this->info);    #1.驗(yàn)證商品庫(kù)存、貨品庫(kù)存    $this->checkGoodsNumber();    #2.查詢規(guī)格名稱、價(jià)格    $this->getSpecData();    #3.組裝購(gòu)物車添加de數(shù)據(jù)    $cartData = $this->setCartData();  p(json_decode($this->input->cookie('cart'),true));    # 一、判斷是否登錄    if(!UID){      //未登錄 數(shù)據(jù)存入Cookie中      //1:獲取cookie中的購(gòu)物車數(shù)據(jù)      $cookieCartData = $this->input->cookie('cart');      //2:判斷cookie中數(shù)據(jù)是否為空      if(empty($cookieCartData)){        //2-1:為空則表示用戶沒(méi)有添加過(guò)購(gòu)物車        //2-1-1.設(shè)置Key-->生成購(gòu)物車數(shù)據(jù)        $key = $cartData['goods_id'].'-'.$cartData['product_id'];        $cookieCart = array($key => $cartData);        //2-1-2.設(shè)置購(gòu)物車返回值(商品數(shù)量、總價(jià))        $this->setCartReturn(1,$cartData['goods_price']);        //2-1-3.設(shè)置Cookie存儲(chǔ)購(gòu)物車數(shù)據(jù)      }else{        //2-2:不為空 表示用戶添加過(guò)購(gòu)物車        //2-2-1.追加購(gòu)物數(shù)據(jù)        $cookieCart = $this->addCartData($cartData,json_decode($cookieCartData,true));        //2-2-2.設(shè)置購(gòu)物車返回值(商品數(shù)量、總價(jià))        $this->setCartReturn(count($cookieCart),array_sum(array_column($cookieCart, 'goods_price')));      }      //3:設(shè)置Cookie存儲(chǔ)購(gòu)物車數(shù)據(jù)      setCookie('cart',json_encode($cookieCart),LEFT_TIME,'/');    }else{      //已登錄 數(shù)據(jù)存入數(shù)據(jù)庫(kù)    }    //返回購(gòu)物車提示數(shù)據(jù)    $this->ajaxReturn($this->msg);  }  /**   * 驗(yàn)證商品庫(kù)存   */  public function checkGoodsNumber()  {    $this->goods->map = array(      'goods_id'     =>  $this->info['goods_id'],      'goods_number >='  => $this->info['buy_number'],    );    $this->goods = $this->goods->find('goods_id,goods_name,goods_sn,goods_img,shop_price');    if(!$this->goods){      $this->msg['msg'] = "商品庫(kù)存不足";      $this->ajaxReturn($this->msg);    }    #驗(yàn)證貨品庫(kù)存    $this->product->map = array(      'goods_id'     =>  $this->info['goods_id'],      'product_attr'   =>  $this->info['prod_attr'],      'product_number >=' => $this->info['buy_number'],    );    $this->prodData = $this->product->find();    if(!$this->prodData){      $this->msg['msg'] = "貨品庫(kù)存不足";      $this->ajaxReturn($this->msg);    }    return true;  }  /**   * 組合規(guī)格名稱、價(jià)格   */  public function getSpecData()  {    $this->goodsAttr->map = inToType(explode("|", $this->info['prod_attr']),'goods_attr_id');    $goodsAttrInfo = $this->goodsAttr->select('goods_attr_value,goods_attr_price');    $this->specData['product_attr_value'] = implode("|", array_column($goodsAttrInfo, 'goods_attr_value'));    $this->specData['product_price'] = array_sum(array_column($goodsAttrInfo,'goods_attr_price'));    # 返回規(guī)格信息 $this->specData  }  /**   * 組裝購(gòu)物車添加的數(shù)組   */  public function setCartData()  {    $this->cartData = array(      'product_id'  =>  $this->prodData['product_id'],      'product_attr' =>  $this->prodData['product_attr'],      'buy_number'  =>  $this->info['buy_number'],      'goods_price'  =>  $this->info['shop_price'],      'goods_sum'   =>  $this->info['shop_price'] * $this->info['buy_number'],      'product_price' =>  '',      'product_attr_value'  =>  '',      'uid'      =>  UID,    );    $this->cartData = array_merge($this->cartData,$this->goods);    #若存在規(guī)格【添加規(guī)格信息】    if(!empty($this->info['prod_attr'])){      $this->cartData['product_price'] = $this->specData['product_price'];      $this->cartData['product_attr_value'] = $this->specData['product_attr_value'];    }    return $this->cartData;    # 購(gòu)物車 添加的總數(shù)據(jù) $this->cartData;  }  /**   * 設(shè)置購(gòu)物車返回提示數(shù)據(jù)   * @param [商品數(shù)量,總價(jià)]   */  public function setCartReturn($number,$prices)  {    $this->msg['code'] = self::STATUS_ON;    $this->msg['data'] = array(        'number'  =>  $number,        'prices'  =>  $prices,    );  }  /**   * 購(gòu)物車 新添加數(shù)據(jù)   * @param [新數(shù)據(jù),原購(gòu)物車數(shù)據(jù)]   */  public function addCartData($newData,$oldData)  {    #組合Key    $key = $newData['goods_id'].'-'.$newData['product_id'];    // #判斷購(gòu)物車中是否有該商品    if(isset($oldData[$key])){      //1.有 合并商品數(shù)量、價(jià)格      $oldData[$key]['buy_number'] = $oldData[$key]['buy_number'] + $newData['buy_number'];      $oldData[$key]['goods_price'] = $newData['goods_price'];      $oldData[$key]['goods_sum'] = $oldData[$key]['buy_number'] * $oldData[$key]['goods_price'];    }else{      //2.沒(méi)有 追加新商品      $oldData[$key] = $newData;    }    #返回購(gòu)物車數(shù)據(jù)    return $oldData;  }}?>

2. 數(shù)據(jù)庫(kù)

CREATE TABLE `shop_goods` ( `goods_id` int(10) unsigned NOT NULL AUTO_INCREMENT, `goods_name` varchar(255) NOT NULL, `type_id` int(11) DEFAULT NULL, PRIMARY KEY (`goods_id`)) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;CREATE TABLE `shop_product` ( `product_id` int(11) unsigned NOT NULL AUTO_INCREMENT, `goods_id` int(11) NOT NULL, `goods_price` decimal(10,2) NOT NULL, `goods_num` int(11) NOT NULL, `goods_sn` varchar(50) NOT NULL, `goods_attr_id` varchar(100) NOT NULL, PRIMARY KEY (`product_id`)) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8;CREATE TABLE `shop_goods_attr` ( `goods_attr_id` int(10) unsigned NOT NULL AUTO_INCREMENT, `goods_id` int(11) NOT NULL, `attr_id` int(11) NOT NULL, `attr_value` varchar(255) NOT NULL, PRIMARY KEY (`goods_attr_id`)) ENGINE=InnoDB AUTO_INCREMENT=126 DEFAULT CHARSET=utf8;

CI購(gòu)物車總結(jié)完畢!!!

希望本文所述對(duì)大家基于CodeIgniter框架的PHP程序設(shè)計(jì)有所幫助。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到PHP教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 通辽市| 红安县| 屏南县| 焦作市| 方正县| 建宁县| 台南市| 宜州市| 湟源县| 长汀县| 兴山县| 行唐县| 天等县| 边坝县| 越西县| 达州市| 九江县| 阿巴嘎旗| 尖扎县| 婺源县| 漾濞| 苍梧县| 固始县| 澄江县| 黑龙江省| 蓝山县| 扎鲁特旗| 滨州市| 遵义市| 威远县| 金山区| 郁南县| 荣昌县| 微山县| 文登市| 平罗县| 辽阳市| 上林县| 壤塘县| 广南县| 牟定县|