基于CI(CodeIgniter)框架实现购物车功能的方法
本文实例讲述了基于CI(CodeIgniter)框架实现购物车功能的方法。分享给大家供大家参考,具体如下:
在商城项目中,购物车是非常重要的一环,此处留下源码,留作笔记!!!
话不多说,往下看:
1.源代码
load->model('goodsModel','goods');
$this->load->model('productModel','product');
$this->load->model('goodsAttrModel','goodsAttr');
}
/**
*[购物车]数据添加
*/
publicfunctioncartAdd()
{
#接收购物车提交数据
$this->info=$this->input->post();
//$this->ajaxReturn($this->info);
#1.验证商品库存、货品库存
$this->checkGoodsNumber();
#2.查询规格名称、价格
$this->getSpecData();
#3.组装购物车添加de数据
$cartData=$this->setCartData();
p(json_decode($this->input->cookie('cart'),true));
#一、判断是否登录
if(!UID){
//未登录数据存入Cookie中
//1:获取cookie中的购物车数据
$cookieCartData=$this->input->cookie('cart');
//2:判断cookie中数据是否为空
if(empty($cookieCartData)){
//2-1:为空则表示用户没有添加过购物车
//2-1-1.设置Key-->生成购物车数据
$key=$cartData['goods_id'].'-'.$cartData['product_id'];
$cookieCart=array($key=>$cartData);
//2-1-2.设置购物车返回值(商品数量、总价)
$this->setCartReturn(1,$cartData['goods_price']);
//2-1-3.设置Cookie存储购物车数据
}else{
//2-2:不为空表示用户添加过购物车
//2-2-1.追加购物数据
$cookieCart=$this->addCartData($cartData,json_decode($cookieCartData,true));
//2-2-2.设置购物车返回值(商品数量、总价)
$this->setCartReturn(count($cookieCart),array_sum(array_column($cookieCart,'goods_price')));
}
//3:设置Cookie存储购物车数据
setCookie('cart',json_encode($cookieCart),LEFT_TIME,'/');
}else{
//已登录数据存入数据库
}
//返回购物车提示数据
$this->ajaxReturn($this->msg);
}
/**
*验证商品库存
*/
publicfunctioncheckGoodsNumber()
{
$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']="商品库存不足";
$this->ajaxReturn($this->msg);
}
#验证货品库存
$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']="货品库存不足";
$this->ajaxReturn($this->msg);
}
returntrue;
}
/**
*组合规格名称、价格
*/
publicfunctiongetSpecData()
{
$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'));
#返回规格信息$this->specData
}
/**
*组装购物车添加的数组
*/
publicfunctionsetCartData()
{
$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);
#若存在规格【添加规格信息】
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;
#购物车添加的总数据$this->cartData;
}
/**
*设置购物车返回提示数据
*@param[商品数量,总价]
*/
publicfunctionsetCartReturn($number,$prices)
{
$this->msg['code']=self::STATUS_ON;
$this->msg['data']=array(
'number'=>$number,
'prices'=>$prices,
);
}
/**
*购物车新添加数据
*@param[新数据,原购物车数据]
*/
publicfunctionaddCartData($newData,$oldData)
{
#组合Key
$key=$newData['goods_id'].'-'.$newData['product_id'];
//#判断购物车中是否有该商品
if(isset($oldData[$key])){
//1.有合并商品数量、价格
$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.没有追加新商品
$oldData[$key]=$newData;
}
#返回购物车数据
return$oldData;
}
}
?>
2.数据库
CREATETABLE`shop_goods`( `goods_id`int(10)unsignedNOTNULLAUTO_INCREMENT, `goods_name`varchar(255)NOTNULL, `type_id`int(11)DEFAULTNULL, PRIMARYKEY(`goods_id`) )ENGINE=InnoDBAUTO_INCREMENT=10DEFAULTCHARSET=utf8; CREATETABLE`shop_product`( `product_id`int(11)unsignedNOTNULLAUTO_INCREMENT, `goods_id`int(11)NOTNULL, `goods_price`decimal(10,2)NOTNULL, `goods_num`int(11)NOTNULL, `goods_sn`varchar(50)NOTNULL, `goods_attr_id`varchar(100)NOTNULL, PRIMARYKEY(`product_id`) )ENGINE=InnoDBAUTO_INCREMENT=18DEFAULTCHARSET=utf8; CREATETABLE`shop_goods_attr`( `goods_attr_id`int(10)unsignedNOTNULLAUTO_INCREMENT, `goods_id`int(11)NOTNULL, `attr_id`int(11)NOTNULL, `attr_value`varchar(255)NOTNULL, PRIMARYKEY(`goods_attr_id`) )ENGINE=InnoDBAUTO_INCREMENT=126DEFAULTCHARSET=utf8;
CI购物车总结完毕!!!
更多关于CodeIgniter相关内容感兴趣的读者可查看本站专题:《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《php优秀开发框架总结》、《ThinkPHP入门教程》、《ThinkPHP常用方法总结》、《ZendFrameWork框架入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于CodeIgniter框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。