php如何实现简单购物车-PHP问题

资源魔 85 0

php完成简略购物车的办法:起首用session记载一个二维数组;而后把session存入array;最初对array进行添加、删除了、修正操作便可。

保举:《PHP视频教程》

本文引见一个php完成的购物车代码,性能完成完好,具备肯定的参考代价

这里咱们为你提供个简略的php购物车代码,从添加购物产物与发作采办了,正在商城开发中,这个性能是少没有了的

详细剖析以下:

对购物车里商品的操作大要上有如下几个:增加商品,删除了商品,和提交定单;

办法实质是:把session存入array,对array进行添加、删除了、修正操作,array中的每一一组记载都是一个商品的信息(个数,价钱等);

处理购物车的思绪是用session记载一个二维数组。一维代表每个商品,二维蕴含了商品的id,商品的数目...等能够自行添加,横竖都是二维了,本人情愿带几何个商品属性就加之去。

购物车的操作流程:起首,登录到网站中阅读商品;而后,采办指定的商品,进入购物车页面中,正在该页面能够完成更改商品数目、删除了商品、清空购物车、持续购物等;最初,天生定单,提交定单等操作。

具体请看弱小的正文;

起首登入;

<body>
<h1>登入页面</h1>
<form action="dengrucl.php" method="post">
    <p>帐号:<input type="text" name="zhang"/></p>
    <p>明码:<input type="text" name="mi"/></p>
    <input type="submit" value="登入"/>
</form>

</body>

图:

登入解决:

<?php
session_start();
include ("db.class.php");
$db = new db();
$zhang = $_POST["zhang"];
$mi = $_POST["mi"];
$sql = "select mi from yonghu WHERE zhang = '{$zhang}'";
$arr = $db->Query($sql);
if(!empty($zhang)&&!empty($mi)&&$mi = $arr){
    $_SESSION["zhang"] = $zhang;
    header("location:zym.php");
}
else
{
    echo "登入失败";
}

?>

很简略的一个登入,没啥说的;

他登入完了当前间接进入主页面:

<body>
<h1>长腿璇购物商城</h1>
<table border="1" cellpadding="0" cellspacing="0" width="100%" >
    <tr>
        <td>代号</td>
        <td>生果称号</td>
        <td>生果价钱</td>
        <td>生果产地</td>
        <td>生果库存</td>
        <td>操作</td>
    </tr>
   <?php
    session_start();
$_SESSION["zhang"] = "xiaoming";//没有做登入的状况下,间接存sessiion
    include ("db.class.php");
    $db = new db();
    $sql = "select * from sgbiao";
    $arr = $db->Query($sql);
    foreach ($arr as $v)
    {
        echo " <tr>
        <td>{$v[0]}</td>
        <td>{$v[1]}</td>
        <td>{$v[2]}</td>
        <td>{$v[3]}</td>
        <td>{$v[4]}</td>
        <td>
        <a href='zymcl.php?ids={$v[0]}'>退出购物车</a>
        
</td>
    </tr>";
    }

    ?>
    <?php
    //这里显示的是 购物车有几何产物,以及产物的总价钱
    $ann=array();
    if(!empty($_SESSION["gwc"]))
    {
        $ann=$_SESSION["gwc"];

    }
    $zhonglei = count($ann);

    $aa=0;
    foreach($ann as $k)
    {

        $k[0];//生果代号
        $k[1];//生果数目
        $sql1="select jiage from sgbiao where ids='{$k[0]}'";

        $danjia=$db->Query($sql1);

        foreach($danjia as $n)
        {

            $aa=$aa + $n[0]*$k[1];
        }


    }
    echo"数目:{$zhonglei}<br/>
价钱:<mark>{$aa}元";
    ?>
</table>

<a href="tijiao.php">查看账户</a>
<a href="ckgwc.php">查看购物车</a>

</body>

来图:

当我点击增加到购物车:

下面的数目与价钱变了,阐明曾经加到了购物车外面;

来看一下是怎样解决的(弱小的正文):

<?php
session_start();
//
$ids = $_GET["ids"];
if(empty($_SESSION["gwc"]))
{
    //假如点击的购物车是空的(第一次增加)

    //假如购物车里是空的,造二维数组,
    $arr = array(
        array($ids,1)
        //一维数组,取ids,第一次点击添加一个
    );
    $_SESSION["gwc"]=$arr;
    //扔到session外面
}
else
    //这里没有是第一次点击
{
    //先判别购物车里能否曾经有了该商品,用$ids
    $arr = $_SESSION["gwc"];
    //把购物车的状态掏出来

    $chuxian = false;
//界说一个变量;用来示意能否呈现,默许是未呈现
    foreach ($arr as $v) {
        //便当他
        //假如这外面有这件商品
        if ($v[0] == $ids) //假如取过去的$v[0](商品的代号)等于$ids那末就证实购物车中曾经有了这一件商品
        {
            $chuxian = true;
            //假如呈现,间接把chuxian改为true

        }
    }
    if($chuxian)
    {
        //购物车中有此商品
        for($i=0;$i<count($arr);$i++)
        {
            if($arr[$i][0] == $ids)
            {
                //把点到的商品编号加1
                $arr[$i][1] += 1;
            }
        }
        $_SESSION["gwc"] = $arr;

    }
        else
            {
                //这里就只剩下:购物车里有货色,然而并无这件商品
                $asg = array($ids,1);
                //设一个小数组
                $arr[] = $asg;
                $_SESSION["gwc"]=$arr;
            }

}
header("location:zym.php")


?>

接上去做一下购物车的页面:

<body>
<h1>查看购物车</h1>
<table width="100%" border="1"cellspacing="0" cellpadding="0">
    <tr>
        <td>商品称号</td>
        <td>商品单价</td>
        <td>商品数目</td>
        <td>操作</td>
    </tr>
   <?php
    session_start();
    if(!empty($_SESSION["gwc"]))
    {
        $arr = array();
        $arr = $_SESSION["gwc"];
        //造数组
    }
    include ('db.class.php');
    $db = new db();
    foreach ($arr as $v)
    {
        global $db;
        $sql = "select * from sgbiao WHERE ids = '{$v[0]}'";
        $att = $db->query($sql);
        foreach ($att as $a)
        {
            echo "<tr>
        <td>{$a[1]}</td>
        <td>{$a[2]}</td>
        <td>{$v[1]}</td>
        <td><a href='shanchu.php?ids={$a[0]}'>删除了</a> </td>
    </tr> ";
//            蔬果的称号
//            单价
//            取int数目
//        这个中央也能够加索引shanchu.php?sy={$v}
        }
    }
    ?>
</table>

<a href="tijiao.php">提交定单</a>
</body>

上图:

能够看到年夜苹果的数目是4,若是我点删除了,其前提即是存正在年夜苹果,且数目年夜于一,点击删除了使数目减一:

白葡萄的数目是1,若我点击删除了,其前提是数目没有年夜于一,使其移除了数组;

说了这些快来看看删除了页面吧:

<?php
session_start();
$ids = $_GET["ids"];
$arr = $_SESSION["gwc"];
//var_dump($arr);
//取索引2(数目)
foreach ($arr as $key=>$v)
{
    if($v[0]==$ids)
    {
        if($v[1]>1){
            //要删除了的数据
           $arr[$key][1]-=1;
        }
        else{
            //数目为1的状况下,移除了该数组
            unset($arr[$key]);
        }
    }

}

$_SESSION["gwc"] = $arr;
//记患上扔到session外面
header("location:ckgwc.php");
//删除了完跳转归去

高能!!

提交定单页面,我只来一个解决页面吧,小同伴如有需求本人填链接便可:

<?php
session_start();
include ("db.class.php");
$db = new db();

//判别用余额能否餍足
$zhang = $_SESSION["zhang"];
//猎取到用户名
$sye = "select zhanghu from yonghu WHERE zhang = '{$zhang}'";
$ye = $db->query($sye);
$ye[0][0];//这是余额

$ann=array();
if(!empty($_SESSION["gwc"]))
{
    $ann=$_SESSION["gwc"];

}
$zhonglei = count($ann);

$aa=0;//总价钱
foreach($ann as $k)
{

    $k[0];//生果代号
    $k[1];//生果数目
    $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)
{
    //钱够,判别库存

    foreach($ann as $v)
    {
        $skc = "select sgname,kucun from sgbiao WHERE ids='{$v[0]}'";
        //生果代号$v[0]
        $akc = $db->query($skc);
        $akc[0][1];//库存
        //比拟能否餍足库存
        if($akc[0][1]<$v[1])
        {
            echo "{$akc[0][0]}库存有余";
            //加入
            exit;
        }

    }
//提交定单:
//i.    从用户账户中扣除了本次采办的总价钱
//ii.    从商品库存中扣除了本次每一种商品的采办数目
//iii.    向定单表以及定单内容表中退出本次采办的商品信息
    //扣除了账户余额
$skcye = "update yonghu set zhanghu = zhanghu-{$aa} WHERE zhang = '{$zhang}'";
    $db->query($skcye,0);
    //扣除了库存
    foreach($ann as $v)
    {
        $skckc = "update sgbiao set kucun = kucun-{$v[1]} WHERE ids='{$v[0]}'";
        //生果代号$v[0]
        $db->query($skckc,0);
    }
    //增加定单信息
    //取以后工夫
    $time = time();
    //主动天生定单号
    $ddh = date("YmdHis");
    $sdd = "insert into dingdan VALUES ('{$ddh}','$zhang','$time')";
    $db->query($sdd,0);
    //增加定单内容
    foreach ($ann as $v)
    {
        $sddxq = "insert into ddneirong VALUES ('','$ddh','{$v[0]}','{$v[1]}')";
        $db->query($sddxq,0);
    }


}
else
{
    echo "钱不敷";
    exit;
}

如斯一来,购物车大要上的性能都已完成;

来看看点击提交定单后的成果:

1.缩小生果库存:

2.增加定单:

3.增加定单内容:

4.扣除了采办人的账户余额:

以上即是购物车内容

以上就是php若何完成简略购物车的具体内容,更多请存眷资源魔其它相干文章!

标签: php php教程 php故障解决 php使用问题 购物车

抱歉,评论功能暂时关闭!