這篇文章將為大家詳細(xì)講解有關(guān)php購(gòu)物車功能的實(shí)現(xiàn)方法,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
三明網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、響應(yīng)式網(wǎng)站設(shè)計(jì)等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)公司成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
php購(gòu)物車功能的實(shí)現(xiàn)方法:首先登錄到網(wǎng)站中瀏覽商品;然后購(gòu)買指定的商品;接著進(jìn)入購(gòu)物車頁(yè)面中,在該頁(yè)面實(shí)現(xiàn)更改商品數(shù)量、刪除商品、清空購(gòu)物車、繼續(xù)購(gòu)物等;最后實(shí)現(xiàn)生成訂單,提交訂單等操作即可。
介紹一個(gè)php實(shí)現(xiàn)的購(gòu)物車代碼以及思路,功能實(shí)現(xiàn)完整,具有一定的參考價(jià)值。
這里我們?yōu)槟闾峁﹤€(gè)簡(jiǎn)單的php購(gòu)物車代碼,從增加購(gòu)物產(chǎn)品與發(fā)生購(gòu)買了,在商城開(kāi)發(fā)中,這個(gè)功能是少不了的。
1.對(duì)購(gòu)物車?yán)锷唐返牟僮鞔篌w上有以下幾個(gè):
添加商品,刪除商品,以及提交訂單;
2.方法本質(zhì)是:
把session存入array,對(duì)array進(jìn)行增加、刪除、修改操作,array中的每一組記錄都是一個(gè)商品的信息(個(gè)數(shù),價(jià)格等);
3.解決購(gòu)物車的思路是用session記錄一個(gè)二維數(shù)組。
一維代表每一個(gè)商品,二維包含了商品的id,商品的數(shù)量...等可以自行增加,反正都是二維了,自己愿意帶多少個(gè)商品屬性就加上去。
4.購(gòu)物車的操作流程:
首先,登錄到網(wǎng)站中瀏覽商品;然后,購(gòu)買指定的商品,進(jìn)入購(gòu)物車頁(yè)面中,在該頁(yè)面可以實(shí)現(xiàn)更改商品數(shù)量、刪除商品、清空購(gòu)物車、繼續(xù)購(gòu)物等;最后,生成訂單,提交訂單等操作。
詳細(xì)請(qǐng)看強(qiáng)大的注釋;
首先登入;
復(fù)制代碼登入頁(yè)面
登入處理:
Query($sql);if(!empty($zhang)&&!empty($mi)&&$mi = $arr){ $_SESSION["zhang"] = $zhang; header("location:zym.php"); }else{ echo "登入失敗"; } ?>復(fù)制代碼
很簡(jiǎn)單的一個(gè)登入,沒(méi)啥說(shuō)的;
他登入完了以后直接進(jìn)入主頁(yè)面:
長(zhǎng)腿璇購(gòu)物商城
代號(hào) | 水果名稱 | 水果價(jià)格 | 水果產(chǎn)地 | 水果庫(kù)存 | 操作 |
{$v[0]} | {$v[1]} | {$v[2]} | {$v[3]} | {$v[4]} | 加入購(gòu)物車 |
來(lái)圖:
當(dāng)我點(diǎn)擊添加到購(gòu)物車:
上面的數(shù)量與價(jià)格變了,說(shuō)明已經(jīng)加到了購(gòu)物車?yán)锩妫?/p>
來(lái)看一下是怎么處理的(強(qiáng)大的注釋):
復(fù)制代碼
接下來(lái)做一下購(gòu)物車的頁(yè)面:
查看購(gòu)物車
商品名稱 | 商品單價(jià) | 商品數(shù)量 | 操作 |
{$a[1]} | {$a[2]} | {$v[1]} | 刪除 |
上圖:
可以看到大蘋果的數(shù)量是4,若是我點(diǎn)刪除,其條件便是存在大蘋果,且數(shù)量大于一,點(diǎn)擊刪除使數(shù)量減一:
白葡萄的數(shù)量是1,若我點(diǎn)擊刪除,其條件是數(shù)量不大于一,使其移除數(shù)組;
快來(lái)看看刪除頁(yè)面吧:
$v) { if($v[0]==$ids) { if($v[1]>1){ //要?jiǎng)h除的數(shù)據(jù) $arr[$key][1]-=1; } else{ //數(shù)量為1的情況下,移除該數(shù)組 unset($arr[$key]); } } }$_SESSION["gwc"] = $arr; //記得扔到session里面 header("location:ckgwc.php"); //刪除完跳轉(zhuǎn)回去復(fù)制代碼
高能??!
提交訂單頁(yè)面,只來(lái)一個(gè)處理頁(yè)面,小伙伴若有需要自己填鏈接即可:
query($sye);$ye[0][0];//這是余額$ann=array();if(!empty($_SESSION["gwc"])) { $ann=$_SESSION["gwc"]; }$zhonglei = count($ann);$aa=0;//總價(jià)格 foreach($ann as $k) { $k[0];//水果代號(hào) $k[1];//水果數(shù)量 $sql1="select jiage from sgbiao where ids='{$k[0]}'"; $danjia=$db->Query($sql1); foreach($danjia as $n) { $aa=$aa + $n[0]*$k[1]; } } //判斷余額是否滿足if($ye[0][0]>=$aa) { //錢夠,判斷庫(kù)存 foreach($ann as $v) { $skc = "select sgname,kucun from sgbiao WHERE ids='{$v[0]}'"; //水果代號(hào)$v[0] $akc = $db->query($skc); $akc[0][1];//庫(kù)存 //比較是否滿足庫(kù)存 if($akc[0][1]<$v[1]) { echo "{$akc[0][0]}庫(kù)存不足"; //退出 exit; } } //提交訂單: //i. 從用戶賬戶中扣除本次購(gòu)買的總價(jià)格 //ii. 從商品庫(kù)存中扣除本次每種商品的購(gòu)買數(shù)量 //iii. 向訂單表和訂單內(nèi)容表中加入本次購(gòu)買的商品信息 //扣除賬戶余額$skcye = "update yonghu set zhanghu = zhanghu-{$aa} WHERE zhang = '{$zhang}'"; $db->query($skcye,0); //扣除庫(kù)存 foreach($ann as $v) { $skckc = "update sgbiao set kucun = kucun-{$v[1]} WHERE ids='{$v[0]}'"; //水果代號(hào)$v[0] $db->query($skckc,0); } //添加訂單信息 //取當(dāng)前時(shí)間 $time = time(); //自動(dòng)生成訂單號(hào) $ddh = date("YmdHis"); $sdd = "insert into dingdan VALUES ('{$ddh}','$zhang','$time')"; $db->query($sdd,0); //添加訂單內(nèi)容 foreach ($ann as $v) { $sddxq = "insert into ddneirong VALUES ('','$ddh','{$v[0]}','{$v[1]}')"; $db->query($sddxq,0); } }else{ echo "錢不夠"; exit; }復(fù)制代碼
如此一來(lái),購(gòu)物車大體上的功能都已實(shí)現(xiàn);
來(lái)看看點(diǎn)擊提交訂單后的效果:
1.減少水果庫(kù)存:
2.添加訂單:
3.添加訂單內(nèi)容:
4.扣除購(gòu)買人的賬戶余額:
關(guān)于php購(gòu)物車功能的實(shí)現(xiàn)方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。