php做网站购物车 你搞懂了吗?

网上购物现已成为时尚,客户选择一个商品将其放入到购物车,然后返回继续购物或者去收银台,这个功能如何实现呢?今天capucivar就将使用PHP来实现这个购物车的功能。

首先,做一个简单的首页,从数据库中查询出来几种商品,显示在首页,再添加一个购买按钮。具体代码如下:

<?php

include ("conn.php");

$sql="select * from produce";//查询所有商品

$rs=mysql_query($sql,$conn);//执行sql语句,得到一个结果集

while($row=mysql_fetch_array($rs))//遍历结果集

{

?>

<table width="343" height="152" border="1"style="float:left">

<tr>

<td width="124"rowspan="3"><img

src="images/<?php echo$row["pimg"]?>" width="123" height="121" border="0"/></td>

<td width="203"height="35">货物名称:<?php echo$row["pname"]?></td>

</tr>

<tr>

<tdheight="28">货物价格:<?php echo$row["price"]?></td>

</tr>

<tr>

<td height="27"align="center"><ahref="buy.php?id=<?php echo $row["pid"]?>&pname=<?php

echo $row["pname"]?>">购买</a></td>

</tr> </table>

<?php

}

?>

对了,conn.php忘了写,它是用来连接数据库的:

<?php

$conn=mysql_connect("localhost","root","");

mysql_select_db("shop",$conn);

mysql_query("set names gb2312");

?>

这样,界面的显示如下:

点击购买的超链接之后到buy.php,在该页面,就要将购买的东西存储起来,我们可以将购买的一件东西放到一个一维数组里,然后将suoyou的一维数组再放到一个二维数组中,最后将二维数组放入到session中。以后不管对购买的物品做如何修改,都可以从session里拿出来进行修改。这样管理起来就很方便了。具体代码如下:

<?php

session_start();//使用session之前一定要将session开启

ob_start();//要清空缓存就必须ob_start()

$pid=$_GET["id"];//得到购买物品的id

$name=$_GET["pname"];//得到购买物品的名字

$arr=$_SESSION["mycar"];//将session中的变量取出来

//下面先判断这个变量是否是数组,可以得到以前是否买过东西

if(is_array($arr))

{

//如果是数组,说明以前买过东西

//如果买过东西又分两种情况:

if(array_key_exists($pid,$arr))

{

//1、array_key_exists($pid,$arr)判断$arr中是否存在键值为$pid的一个一维数组,如果存在的话,就说明此商品以前购买过,只需要把数量加1

$uu=$arr[$pid];
//从二维数组里拿出对应的一维数组,该一维数组包括id name num 三个值

$uu["num"]=$uu["num"]+1;  //改变数量,将数量加1

$arr[$pid]=$uu;
//改完后再将此一维数组放回二维数组中

}

else

{   //2.此商品第一次购买,就将得到的id和name值组成一个一维数组

$arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);

}

}

else

{

$arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);

}

$_SESSION["mycar"]=$arr;//购买完后,将此数组重新放入session中,便可以在各个页面看到此session

ob_clean();//清空缓存

header("location:car.php");//跳转到购物车界面(car.php)

?>

下面就是购物车的代码了:

<?php

session_start();//启用session

$arr=$_SESSION["mycar"];//从session中拿出二维数组

?>

//下面将数组里的数据即客户所购买的物品展示出来

<table width="600" height="37"border="1">

<tr>

<tdwidth="96">商品ID</td>

<tdwidth="158">商品名称</td>

<tdwidth="154">商品数量</td>

<tdwidth="177">删除</td>

</tr>

<?php

foreach($arr as $a)//遍历这个二维数组

{

?>

<tr>

<td width="96"><?phpecho $a["pid"]?></td>//物品的id

<td width="158"><?phpecho $a["name"]?></td>//物品的名称

<td width="154"><?phpecho $a["num"]?></td>//物品的数量

<td width="177"><ahref="delete.php?id=<?php echo $a[pid]?>">删除</a></td>//点击删除超链接到”delete.php”,将物品的id传过去

</tr>

<?php

}

?>

</table>

</form>

<ahref="index.php">返回继续购物</a>//返回到首页

capucivar购买了几件商品之后,界面显示出如下效果:

删除商品时,首先得到可获所要删除商品的id,得到id之后,拿出二维数组里对应得到的id的一维数组,将该一维数组清除掉(unset()),然后将二维数组再重新放到session()里。下面写删除的代码:

<?php

session_start();//启动session

ob_start();//清空缓存必须启动的项

$pid=$_GET["id"];//得到通过get方式传过来的id

$arr=$_SESSION["mycar"];//拿出session里的二维数组

foreach($arr as$key=>$proId)//遍历该二维数组中的键值,这里也就是商品的id

{

if($key==$pid)//判断键值等于传过来的商品id

{

unset($arr[$key]);//清除该一维数组

}

}

$_SESSION["mycar"]=$arr;//将清除之后的二维数组重新放到session里

ob_clean();//清除缓存

header("location:car.php");//跳转到购物车

?>

写完代码之后,capucivar上面已经购买的商品id为2的商品删除,结果如下:

该购物车功能比较简陋,只是实现了购买和删除。其实购物车是比较简单的,只要思路理清了,那就跟计算1+1一样简单。

购物车的功能是这样实现的:购买商品得到该商品的id和name,将这两个值再加上一个数量(1)放到一个一维数组里,一件商品是一个一维数组,那么多件商品自然要用到二维数组了。在此之前,要先查看之前是否购买过该商品,如果购买过的话,在之前的数量上加一,否则的话,就重新创建一个一维数组,将该一维数组放到二维数组里,最后放入session中。删除时,得到要删除商品的id,然后从二维数组里找存放该商品的一维数组,将这个一维数组清除掉,再将二维数组放入session。这样类似上面简单的购物车功能就实现了。

php做网站购物车 你搞懂了吗?

时间: 2024-10-08 02:55:43

php做网站购物车 你搞懂了吗?的相关文章

php做站点购物车 你搞懂了吗?

网上购物现已成为时尚,客户选择一个商品将其放入到购物车,然后返回继续购物或者去收银台,这个功能怎样实现呢?今天capucivar就将使用PHP来实现这个购物车的功能. 首先,做一个简单的首页,从数据库中查询出来几种商品,显示在首页,再加入?一个购买button.详细代码例如以下: <?php include ("conn.php"); $sql="select * from produce";//查询全部商品 $rs=mysql_query($sql,$con

搞懂分布式技术1:分布式系统的一些基本概念

搞懂分布式技术1:分布式系统的一些基本概念 1.分布式 小明的公司又3个系统:系统A,系统B和系统C,这三个系统所做的业务不同,被部署在3个独立的机器上运行,他们之间互相调用(当然是跨域网络的),通力合作完成公司的业务流程. 将不同的业务分部在不同的地方,就构成了一个分布式的系统,现在问题来了,系统A是整个分布式系统的脸面,用户直接访问,用户访问量大的时候要么是速度巨慢,要么直接挂掉,怎么办? 由于系统A只有一份,所以会引起单点失败... 2.集群(Cluster) 小明的公司不差钱,就多买几台

搞懂分布式技术13:缓存的那些事

搞懂分布式技术13:缓存的那些事 缓存和它的那些淘汰算法们 为什么我们需要缓存? 很久很久以前,在还没有缓存的时候--用户经常是去请求一个对象,而这个对象是从数据库去取,然后,这个对象变得越来越大,这个用户每次的请求时间也越来越长了,这也把数据库弄得很痛苦,他无时不刻不在工作.所以,这个事情就把用户和数据库弄得很生气,接着就有可能发生下面两件事情: 1.用户很烦,在抱怨,甚至不去用这个应用了(这是大多数情况下都会发生的) 2.数据库为打包回家,离开这个应用,然后,就出现了大麻烦(没地方去存储数据

彻底搞懂oracle的标量子查询

oracle标量子查询和自定义函数有时用起来比较方便,而且开发人员也经常使用,数据量小还无所谓,数据量大,往往存在性能问题. 以下测试帮助大家彻底搞懂标量子查询. SQL> create table a (id int,name varchar2(10)); Table created. SQL> create table b (id int,name varchar2(10)); Table created. SQL> insert into a values (1,'a1'); 1

猎豹MFC--使用向导快速进行MFC程序设计--不需要全部搞懂,只把重要的几个搞懂即可

新建MFC项目  单文档 文档视图: 如上,向导会为我们自动生成4个类. 每个类中有很多代码,不需压迫我们全部搞懂,我们只把重要的几个搞懂即可. 以前是在窗口中画显示要在视图中画: 所有的显示都是在视图类中: 在视图类属性中添加  paint消息: 记住要在视图对象上添加消息而不是像以前那样在窗口对象上添加. 在视图类上再添加  鼠标单击消息: 来自为知笔记(Wiz)

分分搞懂c#中的委托

分分搞懂c#中的委托: 不说废话,不来虚的概念,不管代码是否有意义,看我的优化之路,你会理解委托了: 源代码1 public class test { //我们不管代码是否有意义,我们直接看代码重构和一步步优化的过程 int flage = 1; public void show(int a) { if (flage == 1) { do1(a); } else if (flage == 2) { do2(a); } else if (flage == 3) { do3(a); } else i

【白话篇】10分钟搞懂字符编码

如上图所示为常见的,让人看了头晕的 几个种编码. 看懂下面几条规则,你就明白他们的关系了. [1]有些人说,GBK严格来说是字符集,而utf-8则是编码,这种区分已经相当模糊了,他们都是"字节到字符的映射关系",所以下面都用编码来说吧. [2] ISO-8859-1 这种编码是单字节编码,衍生于ASCII,表示范围0-255,只要按照ASCII的规则设计的编码,不管是几字节的,都可以和ISO-8859-1兼容. [3]比如说,GBK编码(双字节)能转化成ISO-8859-1编码,是因为

彻底搞懂字符编码(unicode,mbcs,utf-8,utf-16,utf-32,big endian,little endian...)[转]

最近有一些朋友常问我一些乱码的问题,和他们交流过程中,发现这个编码的相关知识还真是杂乱不堪,不少人对一些知识理解似乎也有些偏差,网上百度, google的内容,也有不少以讹传讹,根本就是错误的(例如说 unicode编码是两个字节),各种软件让你选择编码的时候,常常是很长的一个选单,让用户不知道该如何选.基于这样的问题,我就写下我的理解吧,一方面帮助一些需要帮助的人纠正认识,一方面作为自己以后备查的资料. 1. ASCII(American Standard Code for Informati

阶梯博弈(没怎么搞懂)

首先是对阶梯博弈的阐述...博弈在一列阶梯上进行...每个阶梯上放着自然数个点..两个人进行阶梯博弈...每一步则是将一个集体上的若干个点( >=1 )移到前面去..最后没有点可以移动的人输.. 如这就是一个阶梯博弈的初始状态 2 1 3 2 4 ... 只能把后面的点往前面放...如何来分析这个问题呢...其实阶梯博弈经过转换可以变为Nim..把所有奇数阶梯看成N堆石子..做nim..把石子从奇数堆移动到偶数堆可以理解为拿走石子..就相当于几个奇数堆的石子在做Nim..( 如所给样例..2^3