Implémenter un code de panier php simple

coldplay.xixi
Libérer: 2023-04-09 09:16:02
avant
4588 Les gens l'ont consulté

Implémenter un code de panier php simple

Nous vous fournissons ici un simple code de panier php, de l'ajout de produits d'achat à la réalisation d'achats. Dans le développement d'un centre commercial, cette fonction est indispensable

L'analyse spécifique est. comme suit :

Les opérations sur les articles dans le panier comprennent généralement les éléments suivants : ajouter des articles, supprimer des articles et soumettre des commandes

L'essence de la méthode est la suivante : enregistrer la session dans ; le tableau, Ajouter, supprimer et modifier le tableau. Chaque ensemble d'enregistrements du tableau contient des informations sur un produit (numéro, prix, etc.) ;

L'idée de résoudre le panier ; est d'utiliser session pour enregistrer un tableau à deux dimensions . Une dimension représente chaque produit et deux dimensions incluent l'ID du produit, la quantité du produit, etc. Vous pouvez l'ajouter vous-même. Quoi qu'il en soit, il est bidimensionnel. Vous pouvez ajouter autant d'attributs de produit que vous le souhaitez.

Le processus de fonctionnement du panier : tout d'abord, connectez-vous au site Web pour parcourir les produits, puis achetez les produits spécifiés et accédez à la page du panier, où vous pouvez modifier la quantité des produits, supprimer ; les produits, vider le panier, continuer les achats et ainsi de suite, générer des commandes, soumettre des commandes et d'autres opérations ;

Recommandations d'apprentissage associées : Programmation PHP du débutant au compétent

Veuillez consulter les commentaires puissants pour plus de détails

Connectez-vous ; d'abord

<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>
Copier après la connexion

Photo :

Traitement de la connexion :

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

?>
Copier après la connexion

Une connexion très simple, rien à dire

<🎜 ; >Après s'être connecté, il est allé directement à la page principale :

<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=&#39;zymcl.php?ids={$v[0]}&#39;>加入购物车</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=&#39;{$k[0]}&#39;";

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

    foreach($danjia as $n)
    {

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


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

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

</body>
Copier après la connexion

Photo :

Lorsque j'ai cliqué sur Ajouter au panier :

Ce qui précède la quantité est la même que Le prix a changé, indiquant qu'il a été ajouté au panier

Voyons comment il est géré (commentaires puissants) :

<?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")


?>
Copier après la connexion

Ensuite, faites les courses ; page du panier :

<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 (&#39;db.class.php&#39;);
  $db = new db();
  foreach ($arr as $v)
  {
    global $db;
    $sql = "select * from sgbiao WHERE ids = &#39;{$v[0]}&#39;";
    $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=&#39;shanchu.php?ids={$a[0]}&#39;>删除</a> </td>
  </tr> ";
//      蔬果的名称
//      单价
//      取int数量
//    这个地方也可以加索引shanchu.php?sy={$v}
    }
  }
  ?>

</table>

<a href="tijiao.php" rel="external nofollow" rel="external nofollow" >提交订单</a>
</body>
Copier après la connexion

Photo ci-dessus :

Vous pouvez voir que le nombre de grosses pommes est de 4. Si je clique sur supprimer, la condition est qu'il y ait sont de grosses pommes et le nombre est supérieur à un. Cliquez sur Supprimer pour réduire le nombre de un :

Le nombre de raisins blancs est de 1. Si je clique sur Supprimer, la condition est que le nombre ne soit pas supérieur à un. , afin qu'il puisse être supprimé du tableau ;

J'ai dit ceci, allez Jetez un œil à la page de suppression :

<?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");
//删除完跳转回去
Copier après la connexion

Haute énergie ! !

Page de soumission de la commande, je reviendrai uniquement sur une page de traitement, si vous en avez besoin, vous pouvez remplir le lien vous-même :

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

//判断用余额是否满足
$zhang = $_SESSION["zhang"];
//获取到用户名
$sye = "select zhanghu from yonghu WHERE zhang = &#39;{$zhang}&#39;";
$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=&#39;{$k[0]}&#39;";

  $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=&#39;{$v[0]}&#39;";
    //水果代号$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 = &#39;{$zhang}&#39;";
  $db->query($skcye,0);
  //扣除库存
  foreach($ann as $v)
  {
    $skckc = "update sgbiao set kucun = kucun-{$v[1]} WHERE ids=&#39;{$v[0]}&#39;";
    //水果代号$v[0]
    $db->query($skckc,0);
  }
  //添加订单信息
  //取当前时间
  $time = time();
  //自动生成订单号
  $ddh = date("YmdHis");
  $sdd = "insert into dingdan VALUES (&#39;{$ddh}&#39;,&#39;$zhang&#39;,&#39;$time&#39;)";
  $db->query($sdd,0);
  //添加订单内容
  foreach ($ann as $v)
  {
    $sddxq = "insert into ddneirong VALUES (&#39;&#39;,&#39;$ddh&#39;,&#39;{$v[0]}&#39;,&#39;{$v[1]}&#39;)";
    $db->query($sddxq,0);
  }


}
else
{
  echo "钱不够";
  exit;
}
Copier après la connexion
De cette façon , shopping La plupart des fonctions du panier ont été implémentées

Jetons un coup d'œil à l'effet après avoir cliqué pour soumettre la commande :

1. Réduire l'inventaire des fruits :

2. Ajouter une commande :

3. Ajouter le contenu de la commande :

4. Déduisez le solde du compte de l'acheteur :

Ce qui précède est le contenu du panier

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:jb51.net
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!