php实现产品加入购物车功能(1)


Posted in PHP onJuly 23, 2020

今天在练习购物车以及提交订单,写的有点头晕,顺便也整理一下,这个购物车相对来说比较简单,用于短暂存储,并没有存储到数据库,购物车对于爱网购的人来说简直是熟悉的不能再熟悉了,在写购物车之前,我们首先要构思一下,我们需要先从数据库中调出一张表格,这里我用的是fruit表,其次是登录表,我用的是login表,用来调用户名和密码的,所有的都准备好之后就要考虑放入购物车是会有三种情况的:

第一种情况:购物车里面什么都没有

第二种情况:购物车里面已经有此产品了,再次加入 这种情况下考虑到的是 数量要+1

第三种情况:购物车里面有产品了,但是没有此产品

下图是用到的数据库表格:

php实现产品加入购物车功能(1)php实现产品加入购物车功能(1)

下面是登录页面的代码:

<body>
<form action="chuli.php" method="post">
 <div style="margin-left: 500px; margin-top: 200px;
 height: 250px; width: 250px; border: 1px dashed black">
 <div style="margin-left: 100px; "><h3>登录</h3></div>
 <div style="margin-top: 20px">用户名:<input type="text" name="uid"/></div><br/>
 <div>密 码:<input type="password" name="pwd"/></div><br/>
 <div style="margin-left: 180px"><input type="submit" value="登录"/></div>
 </div>

</form>
</body>

登录页面写好之后,需要进入处理页面,从数据库中调出用户名和密码:

<?php
session_start(); //开启session 必须要写到第一行
header("Content-type:text/html;charset=utf-8");

$uid=$_POST["uid"]; //从登录页面获取到用户名和密码
$pwd=$_POST["pwd"];

include("DADB.class.php");
$db=new DADB();

$sql="select password from login where username='{$uid}'";
$arr=$db->Query($sql);

if($arr[0][0]==$pwd && !empty($pwd)) //判断所填写的密码和取到的密码是一样的,而且密码不能为空
{
 $_SESSION["uid"]=$uid;
 header("location:main.php");
}
else
{
 echo"登录失败";
}

登录页面如图所示:

php实现产品加入购物车功能(1)

下面要进入主页面了,从数据库中把所有的水果信息调出来,然后我们再来实现加入购物车这一项功能。

<h2>大苹果购物网</h2>
<?php
session_start();
include("DADB.class.php");
$db=new DADB();
?>
<table border="1" width="100%" cellpadding="0" cellspacing="0">
 <tr>
 <td>代号</td>
 <td>水果名称</td>
 <td>水果价格</td>
 <td>原产地</td>
 <td>货架</td>
 <td>库存量</td>
 <td></td>
 </tr>
 <?php

 $uid=$_SESSION["uid"];

 $sql="select * from fruit";
 $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>{$v[5]}</td>
 <td><a href='add.php?ids={$v[0]}'>购买</a></td> //这里的购买相当于添加购物车的功能 
 </tr>";
 }
 ?>

 <?php
 //这里显示的是 购物车有多少产品,和产品的总价格
 $ann=array();
 if(!empty($_SESSION["gwc"]))
 {
 $ann=$_SESSION["gwc"];
 }
 $zhonglei = count($ann); 

 $sum=0;
 foreach($ann as $k)
 {
 $sql1="select price from fruit where ids='{$v[0]}'";

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

 foreach($danjia as $n)
 {
  $sum=$sum + $n[0]*$k[1];
 }


 }
 echo"购物车有<mark>{$zhonglei}</mark>种商品,总价格为<mark>{$sum}</mark>元";
 ?>
</table>
<div>
<a href="gouwuche.php" rel="external nofollow" rel="external nofollow" >查看购物车</a>
<a href="main.php" rel="external nofollow" rel="external nofollow" >浏览商品</a>
<a href="zhanghu.php" rel="external nofollow" rel="external nofollow" >查看账户</a> </div>

</body>

主页面如图所示:

php实现产品加入购物车功能(1)

最重要的就是添加购物车页面了

<?php
session_start();

$ids = $_GET["ids"];


if(empty($_SESSION["gwc"]))
{
 //1.购物车是空的,第一次点击添加购物车
 $arr = array(
 array($ids,1)
 );
 $_SESSION["gwc"]=$arr;
}
else
{
 //不是第一次点击
 //判断购物车中是否存在该商品
 $arr = $_SESSION["gwc"]; //先存一下

 $chuxian = false;
 foreach($arr as $v)
 {
 if($v[0]==$ids)
 {
  $chuxian = true;
 }
 }

 if($chuxian)
 {
 //3.如果购物车中有该商品

 for($i=0;$i<count($arr);$i++)
 {
  if($arr[$i][0]==$ids)
  {
  $arr[$i][1]+=1;
  }
 }

 $_SESSION["gwc"] = $arr;
 }
 else
 {
 //2.如果购物车中没有该商品
 $asg = array($ids,1);
 $arr[] = $asg;
 $_SESSION["gwc"] = $arr;
 }

}
header("location:gouwuche.php");

这样就可以显示到购物车的页面了,购物车的页面代码如下:

<h2>购物车中有以下商品:</h2>
<table cellpadding="0" cellspacing="0" border="1" width="100%">
 <tr>
 <td>商品名称</td>
 <td>商品单价</td>
 <td>购买数量</td>
 <td></td>
 </tr>
 <?php
 session_start();
 //$uid=$_SESSION["uid"];

 $arr=array();

 if(!empty($_SESSION["gwc"]))
 {
 $arr=$_SESSION["gwc"];
 }
 include("DADB.class.php");
 $db=new DADB();

 foreach($arr as $v)
 {
 global $db;
 $sql="select * from fruit where ids='{$v[0]}'";
 $att=$db -> Query($sql,1);
 foreach($att as $n)
 {
  echo"<tr>
 <td>{$n[1]}</td>
 <td>{$n[2]}</td>
 <td>{$v[1]}</td>
 <td><a href='shanchu.php?ids={$v[0]}'>删除</a></td>
 </tr>";}

 }
 ?>

</table>
<div>
<a href="gouwuche.php" rel="external nofollow" rel="external nofollow" >查看购物车</a> 
<a href="main.php" rel="external nofollow" rel="external nofollow" >浏览商品</a> 
<a href="zhanghu.php" rel="external nofollow" rel="external nofollow" >查看账户</a> </div> 14 15 </body>

这样进入购物车页面显示如图所示:

php实现产品加入购物车功能(1)

这只是比较简单的加入购物车,但是中间还有很多环节没有完善好,比如说加入购物车后,数据库中的产品数量减少、购物车中产品的删除等操作还没有做,后续补上。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP 实现多服务器共享 SESSION 数据
Aug 15 PHP
使用openssl实现rsa非对称加密算法示例
Jan 24 PHP
PHP写的资源下载防盗链类分享
May 12 PHP
ThinkPHP之A方法实例讲解
Jun 20 PHP
PHP网络操作函数汇总
May 18 PHP
php发送邮件的问题详解
Jun 22 PHP
thinkPHP分组后模板无法加载问题解决方法
Jul 12 PHP
PHP实现批量检测网站是否能够正常打开的方法
Aug 23 PHP
php版微信公众平台开发之验证步骤实例详解
Sep 23 PHP
关于php 高并发解决的一点思路
Apr 16 PHP
PHP实现的字符串匹配算法示例【sunday算法】
Dec 19 PHP
PHP树形结构tree类用法示例
Feb 01 PHP
浅谈PHP的排列组合(如输入a,b,c 输出他们的全部组合)
Mar 14 #PHP
php求数组全排列,元素所有组合的方法总结
Mar 14 #PHP
PHP输出多个元素的排列或组合的方法
Mar 14 #PHP
Linux下快速搭建php开发环境
Mar 13 #PHP
php创建图像具体步骤
Mar 13 #PHP
PHP+MYSQL实现读写分离简单实战
Mar 13 #PHP
PHP计算近1年的所有月份
Mar 13 #PHP
You might like
fckeditor上传文件按日期存放及重命名方法
2015/05/22 PHP
php、java、android、ios通用的3des方法(推荐)
2016/09/09 PHP
js函数使用技巧之 setTimeout(function(){},0)
2009/02/09 Javascript
js 模拟气泡屏保效果代码
2010/07/10 Javascript
php与js的区别是什么
2013/08/05 Javascript
jquery toolbar与网页浮动工具条具体实现代码
2014/01/12 Javascript
node.js中的console.info方法使用说明
2014/12/09 Javascript
使用jQueryMobile实现滑动翻页效果的方法
2015/02/04 Javascript
使用jquery插件qrcode生成二维码
2015/10/22 Javascript
js实现符合国情的日期插件详解
2017/01/19 Javascript
JavaScript实现分页效果
2017/03/28 Javascript
javascript算法之二叉搜索树的示例代码
2017/09/12 Javascript
Express系列之multer上传的使用
2017/10/27 Javascript
vue中设置height:100%无效的问题及解决方法
2018/07/27 Javascript
微信小程序云开发之使用云函数
2019/05/17 Javascript
微信小程序实现列表的横向滑动方式
2020/07/15 Javascript
解决vue-photo-preview 异步图片放大失效的问题
2020/07/29 Javascript
微信小程序之高德地图多点路线规划过程示例详解
2021/01/18 Javascript
基于python yield机制的异步操作同步化编程模型
2016/03/18 Python
Python实现读取邮箱中的邮件功能示例【含文本及附件】
2017/08/05 Python
Python使用SQLite和Excel操作进行数据分析
2018/01/20 Python
python之pandas用法大全
2018/03/13 Python
python使用ctypes调用扩展模块的实例方法
2020/01/28 Python
Theory美国官网:后现代都市风时装品牌
2018/05/09 全球购物
WebSphere面试题:在WebSphere里面如何部署一个应用
2015/08/02 面试题
电子专业推荐信范文
2013/11/18 职场文书
车工岗位职责
2013/11/26 职场文书
创业计划书——互联网商机
2014/01/12 职场文书
行政文秘岗位职责范本
2014/02/10 职场文书
电子商务专业毕业生自荐书
2014/06/22 职场文书
产品陈列协议书(标准版)
2014/09/17 职场文书
2015年除四害工作总结
2015/07/23 职场文书
golang特有程序结构入门教程
2021/06/02 Python
Redis中缓存穿透/击穿/雪崩问题和解决方法
2021/12/04 Redis
分享3个非常实用的 Python 模块
2022/03/03 Python
i5-10400f处理相当于i7多少水平
2022/04/19 数码科技