TP電商項(xiàng)目:商品擴(kuò)展類的添加

需求分析:

一件商品可以同時屬于多個擴(kuò)展分類慰丛,搜索任何一個分類都可以搜索出這件商品

第一步 建表

//擴(kuò)展分類表

create table p39_goods_cat(

cat_id? mediumint unsigned not null? comment '分類id',

goods_id? mediumint unsigned not null? comment '商品id',

key goods_id(goods_id),

key cat_id(cat_id)


)engine=InnoDB default charset=utf8 comment '商品的擴(kuò)展分類 ';

第二步 將主分類的代碼復(fù)制到擴(kuò)展分類

<tr>

? ? ? ? ? ? ? ? <td class="label">擴(kuò)展分類:</td>

? ? ? ? ? ? ? ? <td>

? ? ? ? ? ? ? ? ? ? <select name="cat_id">

? ? ? ? ? ? ? ? ? ? <option value="">選擇分類</option>

? ? ? ? ? ? ? ? ? ? <?php foreach ($catData as $k => $v): ?>

? ? ? ? ? ? ? ? ? ? <option value="<?php echo $v['id']; ?>"><?php echo str_repeat('-', 8*$v['level']) . $v['cat_name']; ?></option>

? ? ? ? ? ? ? ? ? ? <?php endforeach; ?>

? ? ? ? ? ? ? ? ? ? </select>


? ? ? ? ? ? ? ? </td>

? ? ? ? ? ? </tr>

如圖所示:


第三步 添加一個按鈕 點(diǎn)擊一次克隆一個擴(kuò)展分類的下拉框

<tr>

? ? ? ? ? ? ? ? <td class="label">擴(kuò)展分類:<input

onclick="$('#cat_list').append($('#cat_list').find('select').eq(0).clone());"


?type="button" id="btn_add_cat" value="添加一個"/></td>

? ? ? ? ? ? ? ? <td>

? ? ? ? ? ? ? ? ? ? <select name="cat_id">

? ? ? ? ? ? ? ? ? ? <option value="">選擇分類</option>

? ? ? ? ? ? ? ? ? ? <?php foreach ($catData as $k => $v): ?>

? ? ? ? ? ? ? ? ? ? <option value="<?php echo $v['id']; ?>"><?php echo str_repeat('-', 8*$v['level']) . $v['cat_name']; ?></option>

? ? ? ? ? ? ? ? ? ? <?php endforeach; ?>

? ? ? ? ? ? ? ? ? ? </select>

? ? ? ? ? ? ? ? </td>

? ? ? ? ? ? </tr>

修改為:

<tr>

? ? ? ? ? ? ? ? <td class="label">擴(kuò)展分類:<input type="button" onclick="$('#cat_list').append($('#cat_list').find('li').eq(0).clone());"? ? id="btn_add_cat" value="添加一個"/></td>

? ? ? ? ? ? ? ? <td >

? ? ? ? ? ? ? ? ? ? <ul? id="cat_list"? >

? ? ? ? ? ? ? ? ? ? ? ? <li>

? ? ? ? ? ? ? ? ? ? <select name="ext_cat_id[]">

? ? ? ? ? ? ? ? ? ? <option value="">選擇分類</option>

? ? ? ? ? ? ? ? ? ? <?php foreach ($catData as $k => $v): ?>

? ? ? ? ? ? ? ? ? ? <option value="<?php echo $v['id']; ?>"><?php echo str_repeat('-', 8*$v['level']) . $v['cat_name']; ?></option>

? ? ? ? ? ? ? ? ? ? <?php endforeach; ?>

? ? ? ? ? ? ? ? ? ? </select>

? ? ? ? ? ? ? ? ? ? ? ? </li>

? ? ? ? ? ? ? ? ? ? </ul>


? ? ? ? ? ? ? ? </td>

? ? ? ? ? ? </tr>

如圖所示:


第四步? 在修改商品模型劫拗,在商品添加之后罢防,獲取商品的ID再接收表單中的擴(kuò)展分類ID數(shù)組插入到分類表

protected function _after_insert($data,$option){

? ? ? ? $ecid=I('post.ext_cat_id');

? ? ? ? if($ecid)

? ? ? ? {

? ? ? ? ? ? $gcModel=D('goods_cat');

? ? ? ? ? ? foreach($ecid as $k=>$v){

? ? ? ? ? ? ? ? if(empty($v))

? ? ? ? ? ? ? ? ? ? continue;

? ? ? ? ? ? ? ? $gcModel->add(array(

? ? ? ? ? ? ? ? ? ? 'cat_id'=>$v,

? ? ? ? ? ? ? ? ? ? 'goods_id'=>$data['id'],


? ? ? ? ? ? ? ? ));

? ? ? ? ? ? }


? ? ? ? }

第五步 在商品列表中再添加一列:“擴(kuò)展分類名稱”

修改商品模型search方法

public function search($perPage=5){

? ? ? ? //取出總的記錄數(shù)

//echo 1;

//echo "<br/>";

? ? ? ? $count=$this->where($where)->count();

? ? ? ? //echo $count;

? ? ? ? ////搜索頁

? ? ? ? $where=array();

? ? ? ? $gn=I('get.gn');

? ? ? ? if($gn) {

? ? ? ? $where['a.goods_name']=array('like',"%$gn%");}//

? ? ? ? $fp=I('get.fp');

? ? ? ? $tp=I('get.tp');

? ? ? ? if($fp&&$tp){

? ? ? ? ? ? $where['a.shop_price']=array('between',array($fp,$tp));

? ? ? ? }

? ? ? ? elseif ($fp) {

? ? ? ? ? ? $where['a.shop_price']=array('egt',$fp);


? ? ? ? }elseif ($tp) {

? ? ? ? ? ? ? $where['a.shop_price']=array('elt',$tp);

? ? ? ? }

? ? ? ? //添加時間

? ? ? ? $fa=I('get.fa');

? ? ? ? $ta=I('get.ta');

? ? ? ? ? if($fa && $ta){

? ? ? ? ? ? $where['a.addtime']=array('between',array($fa,$ta));

? ? ? ? }

? ? ? ? elseif ($fa) {

? ? ? ? ? ? $where['a.addtime']=array('egt',$fa);


? ? ? ? }elseif ($ta) {

? ? ? ? ? ? ? $where['a.addtime']=array('elt',$ta);

? ? ? ? }

? ? ? ? $brandId=I('get.brand_id');

? ? ? ? if($brandId){

? ? ? ? $where['a.brand_id']=array('eq',$brandId);}

? ? ? ? $catId=I('get.cat_id');

? ? ? ? ? if($catId){

? ? ? ? ? ? ? $catModel=D('category');

? ? ? ? ? ? ? $children=$catModel->getChildren($catId);

? ? ? ? ? ? ? $children[]=$catId;

? ? ? ? ? ? $where['a.cat_id']=array('IN',$children);

? ? ? ? ? }

? ? ? ? //是否上架

? ? ? ? $ios=I('get.ios');

? ? ? ? if($ios){


? ? ? ? ? ? $where['a.is_on_sale']=array('eq',$ios);

? ? ? ? }


? ? ? ? //生成翻頁類的對象

? ? ? ? $pageObj=new \Think\Page($count,$perPage);

? ? ? ? ? $pageObj->setConfig('next','下一頁');

? ? ? ? ? ? ? ? ? $pageObj->setConfig('prev','上一頁');

? ? ? ? //生成頁面顯示的上一頁敬扛,下一頁的字符串

? ? ? ? $pageString=$pageObj->show();

? ? ? ? /***************** 排序 *****************/

$orderby = 'a.id';? ? ? // 默認(rèn)的排序字段

$orderway = 'desc';? // 默認(rèn)的排序方式

$odby = I('get.odby');

if($odby)

{

if($odby == 'id_asc')

$orderway = 'asc';

elseif ($odby == 'price_desc')

$orderby = 'shop_price';

elseif ($odby == 'price_asc')

{

$orderby = 'shop_price';

$orderway = 'asc';

}

}




? ? ? ? //取數(shù)據(jù)

? ? ? ? $data=$this->order("$orderby $orderway")


? ? ? ? ? ? ? ->field('a.*,b.brand_name,c.cat_name,e.ext_cat_name')

? ? ? ? ? ? ? ->alias('a')

? ? ? ? ? ? ? // ->join('LEFT JOIN p39_brand b ON a.brand_id=b.id')

? ? ? ? ? ? ? ? ->join('LEFT JOIN __BRAND__ b ON a.brand_id=b.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ c ON a.cat_id=c.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __GOODS_CAT__ d? ON a.id=d.goods_id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ e ON d.cat_id=e.id


')

? ? ? ? ? ? ? ? ->where($where)

? ? ? ? ? ? ? ? ->limit($pageObj->firstRow.','.$pageObj->listRows)

? ? ? ? ? ? ? ? ->select();

? ? ? ? // print_r($data);

? ? ? ? return array(

? ? ? ? ? 'data'=>$data,

? ? ? ? ? ? 'page'=>$pageString,

? ? ? ? );

? ? }

如圖所示:


解決辦法‘:

分組

$data=$this->order("$orderby $orderway")


? ? ? ? ? ? ? ->field('a.*,b.brand_name,c.cat_name,e.cat_name ext_cat_name')

? ? ? ? ? ? ? ->alias('a')

? ? ? ? ? ? ? // ->join('LEFT JOIN p39_brand b ON a.brand_id=b.id')

? ? ? ? ? ? ? ? ->join('LEFT JOIN __BRAND__ b ON a.brand_id=b.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ c ON a.cat_id=c.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __GOODS_CAT__ d? ON a.id=d.goods_id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ e ON d.cat_id=e.id


')

? ? ? ? ? ? ? ? ->where($where)

? ? ? ? ? ? ? ? ->group('a.id')

? ? ? ? ? ? ? ? ->limit($pageObj->firstRow.','.$pageObj->listRows)

? ? ? ? ? ? ? ? ->select();



運(yùn)用一個函數(shù):

GROUP_CONCAT

$data=$this->order("$orderby $orderway")


? ? ? ? ? ? ? ->field('a.*,b.brand_name,c.cat_name,GROUP_CONCAT(e.cat_name) ext_cat_name')

? ? ? ? ? ? ? ->alias('a')

? ? ? ? ? ? ? // ->join('LEFT JOIN p39_brand b ON a.brand_id=b.id')

? ? ? ? ? ? ? ? ->join('LEFT JOIN __BRAND__ b ON a.brand_id=b.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ c ON a.cat_id=c.id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __GOODS_CAT__ d? ON a.id=d.goods_id

? ? ? ? ? ? ? ? ? ? ? ? ? LEFT JOIN __CATEGORY__ e ON d.cat_id=e.id


')


擴(kuò)展:

使用SEPARATOR

->field('a.*,b.brand_name,c.cat_name,GROUP_CONCAT(e.cat_name SEPARATOR "<br/>") ext_cat_name')


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末粥诫,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蔑水,更是在濱河造成了極大的恐慌邢锯,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搀别,死亡現(xiàn)場離奇詭異丹擎,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)领曼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評論 3 385
  • 文/潘曉璐 我一進(jìn)店門鸥鹉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蛮穿,“玉大人庶骄,你說我怎么就攤上這事毁渗。” “怎么了单刁?”我有些...
    開封第一講書人閱讀 157,435評論 0 348
  • 文/不壞的土叔 我叫張陵灸异,是天一觀的道長。 經(jīng)常有香客問我羔飞,道長肺樟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,509評論 1 284
  • 正文 為了忘掉前任逻淌,我火速辦了婚禮么伯,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘卡儒。我一直安慰自己田柔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評論 6 386
  • 文/花漫 我一把揭開白布骨望。 她就那樣靜靜地躺著硬爆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪擎鸠。 梳的紋絲不亂的頭發(fā)上缀磕,一...
    開封第一講書人閱讀 49,837評論 1 290
  • 那天,我揣著相機(jī)與錄音劣光,去河邊找鬼袜蚕。 笑死,一個胖子當(dāng)著我的面吹牛绢涡,可吹牛的內(nèi)容都是我干的廷没。 我是一名探鬼主播,決...
    沈念sama閱讀 38,987評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼垂寥,長吁一口氣:“原來是場噩夢啊……” “哼颠黎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起滞项,我...
    開封第一講書人閱讀 37,730評論 0 267
  • 序言:老撾萬榮一對情侶失蹤狭归,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后文判,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體过椎,經(jīng)...
    沈念sama閱讀 44,194評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評論 2 327
  • 正文 我和宋清朗相戀三年戏仓,在試婚紗的時候發(fā)現(xiàn)自己被綠了疚宇。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亡鼠。...
    茶點(diǎn)故事閱讀 38,664評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖敷待,靈堂內(nèi)的尸體忽然破棺而出间涵,到底是詐尸還是另有隱情,我是刑警寧澤榜揖,帶...
    沈念sama閱讀 34,334評論 4 330
  • 正文 年R本政府宣布勾哩,位于F島的核電站,受9級特大地震影響举哟,放射性物質(zhì)發(fā)生泄漏思劳。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評論 3 313
  • 文/蒙蒙 一妨猩、第九天 我趴在偏房一處隱蔽的房頂上張望潜叛。 院中可真熱鬧,春花似錦壶硅、人聲如沸威兜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牡属。三九已至,卻和暖如春扼睬,著一層夾襖步出監(jiān)牢的瞬間逮栅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評論 1 266
  • 我被黑心中介騙來泰國打工窗宇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留措伐,地道東北人。 一個月前我還...
    沈念sama閱讀 46,389評論 2 360
  • 正文 我出身青樓军俊,卻偏偏與公主長得像侥加,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子粪躬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評論 2 349

推薦閱讀更多精彩內(nèi)容