php簡略 購物車~ 學習筆記part1
來源:互聯網
上載者:User
php簡單 購物車~ 學習筆記part1
購物車 ,學習 ,part1
建表
wrox_shop_category 產品類別ID 和名稱
create table wrox_shop_category (
category_id integer unsigned not null auto_increment,
category_name varchar(100) not null,
primary key (category_id)
)
ENGINE= InnoDB default character set latinl
collate latinl_general_cs;
商品類別表
wrox_shop_inventory
create table wrox_shop_inventory (
item_id integer unsigned not null auto_increment,
item_name varchar(100) not null,
item_description text default '',
price double(5,2) not null,
item_image varchar(255) not null,
category_id integer unsigned not null,
primary key (item_id),
foreign key (category_id)
references wrox_shop_category(category_id)
on delete cascade
)
engine = InnoDB default character set latinl
callate latinl_general_cs auto_increment=0;
這兩張表多指定InnoDB儲存引擎,引用on delete cascade將類別刪除後,商品也將自動刪除.
代碼檔案
ShoppingCart類 ,該類如何編寫,之後寫shop.php和cart.php ,之後建立管理檔案 產生商品資料庫及商品條目
ShoppingCart,負責維護商品列表直到結帳。
包含屬性:
contents,以數組形式返回購物車中的所有商品
isEmpty ,購物車是否是空
totalItems,不同種類的商品的總數量
totalQty 購物車中商品的總數量
methods :
construct()
addItem(item[,qty])
qtyItem(item)
removeItem(item)
removeAll()
商品列表,儲存商品列表需要用到一個私人屬性,初始化時候,將該屬性初始化為一個空數組,之後每添加一個商品,此數組負責儲存用產品ID索引的商品的數量???
class ShoppingCart
{
private $items;
public function _construct()
{
$this->items = array();
}
public fuction _get($value)
{
switch($value)
{
case 'contents':
return $this->items;
break;
case 'isEmpty':
return (count($this->items) == 0 );
break;
case 'totalItems':
return (count($this->items));
break;
case 'totalQty':
return array_sum($this->items);
break;
}
}
public funciton addItem($item, $qty =1)
{
$this->items[$item] = $qty;
} //addItem行數將接收商品的Id,並把該值賦值於內部的items屬性
public function qtyItem($item)
{
if (!isset($this->items[$item])
{
return 0;
}
else
{
return $this->items[$item];//返回了商品的數量
}
}
public function removeItem($item)
{
unset($this ->items[$item]);
}
public function removeAll()
{
$this->items = array();
}
}
?>