在电子商务中实现购物车的方法
手推车”功能的实现【来源:开店乐www.KaiDianLe.Com】
“手推车”是在线购物网站(零售)中一项重要的功能。本文将要探讨用ASP程序实现“手推车”功能的技巧。要想在网站上实现“手推车”功能,有好几种方法,比如用Cookie、Session或者隐藏帧等。这几种方法各有优缺点,这里着重讨论用Cookie来实现“手推车”功能。
用Cookie实现 “手推车”功能的优缺点
Cookie是通过服务器端CGI、脚本或者客户端脚本把信息保存在客户机上的,以便为服务器或客户机再次使用这些信息提供方便。在javascript中有一些专门用来对Cookie进行操作的函数,如设置Cookie值的Setcookie(name,value),删除Cookie的Deletecookie(name)等(详细见源码)。使用Cookie来保存“手推车”信息的优点是,即使当用户不小心关闭了浏览器窗口,“手推车”中的信息也不会丢失,并且它占用很少的服务器端资源,缺点是必须要求用户端浏览器支持Cookie并且打开它。
“手推车”包含的功能子项
1.把商品添加到“手推车”,就是订购。
2.从“手推车”中删掉已订购的商品。
3.修改“手推车”中某一商品的数量。
4.清空“手推车”。
5.显示,统计“手推车”中的商品。
往“手推车”中 添加商品
非常简单,就是把某一商品的信息(名称、价格、数量、折扣等)写入Cookie即可。这里不必把商品的所有信息都写入Cookie,只要记下商品在数据库中编号或ID(这里用catid表示)与商品的数量就行。在显示“手推车”信息时,根据catid可以从商品数据库中查询出这种商品的所有具体信息。往“手推车”中添加商品的实现方法如下:
function Addcat(catid,number){ //把商品添加到“手推车”函数
if (number<=0)DeleteCookie(″mycat″+catid); //如果商品的数量少于或等于0,则删除该商品
else SetCookie(″mycat″+catid,catid+″,″+number); //把商品ID与数量写入Cookie
var cat=window.open(″showcat.asp″,″cat″,″toolbar=no,menubar=no,location=no,status=no,width=420,height=280″); //打开一个新窗口来显示统计的商品信息,即显示“手推车”}
从“手推车”中 删掉商品
也就是把Cookie中的该商品信息删除掉,调用Deletecat(catid)即可。
function Deletecat(catid){
DeleteCookie(″mycat″+catid); //从Cookie中删除
var cat=window.open(″showcat.asp″,″cat″,″toolbar=no,menubar=no,location=no,status=no,width=420,height=280″); //在CAT窗口显示统计的商品信息,即刷新显示“手推车” }
修改“手推车”中 商品的数量
原理跟往“手推车”中添加商品是一样的,只不过把商品的数量修改成现在所要的数量。
显示与统计 “手推车”中的商品信息
显示的效果由Showcat.asp实现。这里使用了ASP中Request.Cookies集合。Request.Cookies用来检索客户中Cookie值。我们通过遍历 Cookies 集合中的所有 Cookie 值取出我们的“手推车”的信息,然后从中分离出商品ID与商品数量。这里使用了VBscript中的SPLIT函数,SPLIT函数返回基于 0 的一维数组,其中包含指定数目的子字符串。
取出商品ID与商品数量后再根据商品ID从商品数据库中查询出该商品的具体信息,最后输出商品的名称、单价、折扣、数量和小计等,并累计商品总件数与商品总金额。
源代码如下:
Showcat.asp
<html><head><title>Cat</title></head>
<body>
<form name=cat>
<table border="1" width="360" cellspacing="0" cellpadding="3" bordercolorlight="#FFFFFF" bordercolor="#008000">
<tr>
<td width="100%" colspan="5" align="center"><b>您的手推车信息</b></td>
</tr>
<tr>
<td width="45">名称</td>
<td width="45">单价</td>
<td width="45">折扣</td>
<td width="45">数量</td>
<td width="45">小计</td>
<td width="135"> </td>
</tr>
<% dim conn,rs,sqlstr,cook,catid,number,sum,allnum,i
i=0
set conn=server.createobject("ADODB.CONNECTION") '建立数据库ADO连接实例
conn.open "DSN","USERID","PWD" '打开数据库连接
set rs=Server.CreateObject("ADODB.Recordset") '建立数据库ADO记录集连接实例
for each cook in request.cookies '遍历 Cookies 集合
if instr(cook,"mycat") then '判断是否“手推车”信息
catid=split(request.cookies(cook),",")[0] '分离出商品ID
number=split(request.cookies(cook),",")[1] '分离出商品数量
sqlstr="select * from cat where id="&catid&"" 'SQL查询语句
rs.open conn,sql,1,3 '执行查询,产生记录集
xiaoji=rs("单价")*rs("折扣")*number '计算小计
response.write "<tr><td width=45 ><font size=2 color=#800080>"&rs("名称")&"</font></td>"
response.write "<td width=45 ><font size=2 color=#800080>"&rs("单价")&"</font></td>"
response.write "<td width=45 ><font size=2 color=#800080>"&rs("折扣")&"</font></td>"
response.write "<td width=45 ><input type=text name=number"&i&" value="&number&" size=4></td>"
response.write "<td width=45 ><font size=2 color=#800080>"&xiaoji&"</font></td>"
response.write "<td width=135><input type=button value=更新 onclick=Addcat("&rs("ID")&",document.cat.number"&i&".value)> <input type=button value=删除 onclick=Deletecat("&rs("ID")&")></td></tr>
allnum=allnum+number '累计商品总件数
sum=sum+xiaoji '累计总金额
rs.close
i=i+1
end if
next
set rs=nothing
set conn=nothing
%>
<tr>
<td width="45">合计</td>
<td width="45"> </td>
<td width="45"> </td>
<td width="45"><%=allnum%></td>
<td width="45"><%=sum%></td>
<td width="135"><%=sum%></td>
</tr>
<tr>
<td width="360" colspan="6"> <font size="2"><a href="checkout.asp"><font color="#FF0000">结帐</font></a>
<a href=javascript:window.close()><font color="#008000">继续购物</font></a></font> <a href=javascript:Clearcookie()><font size="2" color="#0000FF">清空“手推车”</font></a></td>
</tr>
</table>
</form>
</body>
</html>
javascript中操作COOKIE的函数源码如下:
function Setcookie (name, value) { //设置名称为name,值为value的Cookie
var argc = SetCookie.arguments.length;
var argv = SetCookie.arguments;
var path = (argc > 3) ? argv[3] : null;
var domain = (argc > 4) ? argv[4] : null;
var secure = (argc > 5) ? argv[5] : false;
documents.cookie = name + "=" + value +
((path == null) ? "" : ("; path=" + path)) +
((domain == null) ? "" : ("; domain=" + domain)) +
((secure == true) ? "; secure" : "");
}
function Deletecookie (name) { //删除名称为name的Cookie
var exp = new Date();
exp.setTime (exp.getTime() - 1);
var cval = GetCookie (name);
documents.cookie = name + "=" + cval + "; expires=" + exp.toGMTString();
}
function Clearcookie() //清除COOKIE
{
var temp=documents.cookie.split(";");
var loop3;
var ts;
for (loop3=0;loop3<temp.length;loop3++)
{
ts=temp[loop3].split("=")[0];
if (ts.indexOf('mycat')!=-1)
DeleteCookie(ts); //如果ts含“mycat”则执行清除
}
}
function getCookieVal (offset) { //取得项名称为offset的cookie值
var endstr = documents.cookie.indexOf (";", offset);
if (endstr == -1)
endstr = documents.cookie.length;
return unescape(documents.cookie.substring(offset, endstr));
}
function GetCookie (name) { //取得名称为name的cookie值
var arg = name + "=";
var alen = arg.length;
var clen = documents.cookie.length;
var i = 0;
while (i < clen) {
var j = i + alen;
if (documents.cookie.substring(i, j) == arg)
return getCookieVal (j);
i = documents.cookie.indexOf(" ", i) + 1;
if (i == 0) break;
}
return null;
}
【日期:2006-8-7】【作者:不祥】【转载自:开店乐】
相关文章:
最好的网上开店系统:凡人网络购物系统免费下载
Rs.open sql,conn,A,B 的A、B各代表什么?
ASP开发中存储过程应用全接触
Oracle大文本在ASP中存取问题的解决
数据分页方法新思路,速度非常快!
ASP+vbscript写的万能查询表达式生成器
常用网站数据库SQL操作语句
ASP程序与SQL存储过程详解
ASP脚本一空间绑定多个域名代码
WEB编程开发常用的代码大全
解决大字段在Form中Post出错的方法
学习ASP之编写安全的ASP代码
ASP程序应用之模板采用
防止别人批量采集功能的ASP代码
网页图片下拉选择控件使用实例
平时写程序的时候出错时的解决方法
“在线访客”的制作方法
ASP中数据库调用时常见错误的现象和解决
ASP 编程中20个非常有用的例子
经典实用的基础asp程序整理
ASP中从数据库读取二进制文件数据代码
ASP动态生成的javascript表单验证代码
在电子商务中实现购物车的方法
ASP利用Google实现在线翻译功能
实现千万级数据分页的存储过程
详细说明用ASP和WML来实现数据库查询
ASP访问INTERBASE数据库
ASP安全配置不完全手册
在ASP中如何访问Novell下的数据库
ASP进阶学习必经之认识数学函数11种
初学者必读 ASP运行环境的搭建
解析asp的脚本语言
学习使用ASP对象和组件
让ASP程序运行于非Windows平台
通过启动脚本来感受ASP的力量
一些不长见的ASP调用存储过程的技巧
使用ASP脚本技术
优化Web数据库页面
Asp限制IP访问代码
ACCESS数据库防下载另类方法
ASP浏览器性能组件
细说ASP中Counters 组件
全面解析Server对象
ASP 内建对象Request和Respones
深入研究Application和Session对象
使用ASP、VB和XML建立运行于互联网上的应用程序
在客户端执行数据库记录的分页显示
对ASP脚本源代码进行加密
用代码打开Access文件的两种方法
使用Visual InterDev进行小组开发
用JScript脚本实现分页的另类办法
ASP中Cookie读写的实现方法
如何使用ASP建立虚拟的FTP服务器
在ASP中自动创建多级文件夹的函数
一个硬盘文件搜索的Asp源码
ASP使用MYSQL数据库全攻略
ASP上传数据流格式分析详解
ASP汉字转换UTF-8及UTF-8转换GB2312
ASP常用数据库连接及操作的方法
ASP编程中常用SQL命令使用方法
ASP查询记录时RecordCount=-1问题
让你的WAP网站有更好的兼容性
如何注册服务器端组件
轻松实现任何程序和动易整合
在服务器端调用winzip命令行对上传的多个文件打包压缩
用ASP制作强大的搜索引擎
ASP彩色校验码的制作
ASP 系列函数大全
ASP程序处理进程进度条
Asp无组件生成缩略图
用ASP实现自动建站.实现虚拟二级目录
删除Access数词库中的空记录
ASP身份证验证代码函数
ASP写的自动生成SELECT表单的函数
几种打开记录集方式的比较
用ASP实现汉字转拼音的功能
ASP分页代码,已经写成类了,值得参考
ASP下载系统防盗链方法
Global.asa文件用法大全
如何防止页面中的敏感信息被提取
Delphi编写组件封装asp代码的基本步骤
制做行背景颜色交替变换的表格
如何用foreach遍历页面上所有的TextBox
将数据库中的信息存储至XML文件中
用Asp写个加密和解密的类
如何固定表格的标题行和标题列
ASP小偷(远程数据获取)程序入门教程
Asp编写不再让人讨厌的自动弹出窗口
用ASP实现在线压缩与解压缩
使用组件封装ASP的数据库操作
ASP中读写注册表
ASP判断函数一览及网页制作常用技术
ASP中Cookie使用指南
随机产生用户密码(good)
ASP:如何对身份证的籍贯进行验证
ASP产生随机密码的函数
ASP+ADO实现数据读写简单示例
一个简单的用户登录接口ASP实现
ASP+SQL Server构建网页防火墙
一个通用的保护ASP系统的方法
利用ASP发送和接收XML数据的处理方法
版权所有:Kaidianle.Com 联系方式:Shnxn@Yhaoo.Com.Cn 京ICP备06028743号 在线留言