基于Cookie的购物车
var Cookies = {};
Cookies.set = function (name, value) {
var argv = arguments;
var argc = arguments.length;
var expires = (argc > 2) ? argv[2] : null;
var path = (argc > 3) ? argv[3] : '/';
var domain = (argc > 4) ? argv[4] : null;
var secure = (argc > 5) ? argv[5] : false;
document.cookie = name + "=" + escape(value) +
((expires == null) ? "" : ("; expires=" + expires.toGMTString())) +
((path == null) ? "" : ("; path=" + path)) +
((domain == null) ? "" : ("; domain=" + domain)) +
((secure == true) ? "; secure" : "");
}; Cookies.get = function (name) {
var arg = name + "=";
var alen = arg.length;
var clen = document.cookie.length;
var i = 0;
var j = 0;
while (i < clen) {
j = i + alen;
if (document.cookie.substring(i, j) == arg)
return Cookies.getCookieVal(j);
i = document.cookie.indexOf(" ", i) + 1;
if (i == 0)
break;
}
return null;
}; Cookies.clear = function (name) {
if (Cookies.get(name)) {
var expdate = new Date();
expdate.setTime(expdate.getTime() - (86400 * 1000 * 1));
Cookies.set(name, "", expdate);
}
}; Cookies.getCookieVal = function (offset) {
var endstr = document.cookie.indexOf(";", offset);
if (endstr == -1) {
endstr = document.cookie.length;
}
return unescape(document.cookie.substring(offset, endstr));
}; var Global = {};
Global.getParam = function (param) {
var params = Ext.urlDecode(location.search.substring(1));
return param ? params[param] : params;
}
//购物车
var ShoppingCart = {};
//新增商品
ShoppingCart.add = function (cid, did, price) {
var ck = Global.getParam("sid") + "_" + Global.getParam("uid") + "_sc";
if (Cookies.get(ck) == null) {
var exp = new Date();
exp.setTime(exp.getTime() + 7 * 24 * 60 * 60 * 1000);
Cookies.set(ck, JSON.stringify({ TotalCount: 0, TotalMoney: 0 }), exp);
}
var cart = eval('(' + Cookies.get(ck) + ')');
//类别
if (cart[cid] == undefined) {
cart[cid] = { num: 0 };
}
//商品
if (cart[did] == undefined) {
cart[did] = { cid: cid, num: 0 };
}
//计算
if (cart[did].num < 9) {
cart[did].num = cart[did].num + 1;
//类别(方便查找)
cart[cid].num = cart[cid].num + 1;
//总数量,总金额
cart["TotalCount"] = cart["TotalCount"] + 1;
cart["TotalMoney"] = cart["TotalMoney"] + price;
} console.log(cart);
Cookies.set(ck, JSON.stringify(cart));
};
//移除商品
ShoppingCart.remove = function (cid, did, price) {
var ck = Global.getParam("sid") + "_" + Global.getParam("uid") + "_sc";
var cart = eval('(' + Cookies.get(ck) + ')');
if (cart[did] != undefined && cart[did].num > 0) {
cart[did].num = cart[did].num - 1;
cart["TotalCount"] = cart["TotalCount"] - 1;
cart["TotalMoney"] = cart["TotalMoney"] - price;
if (cart[cid] != undefined) {
cart[cid].num = cart[cid].num - 1;
}
}
Cookies.set(ck, JSON.stringify(cart));
};
//清空购物车
ShoppingCart.clear = function () {
var ck = Global.getParam("sid") + "_" + Global.getParam("uid") + "_sc";
Cookies.clear(ck);
};
//获取某商品的数量
ShoppingCart.getGoodNum = function (did) {
var ck = Global.getParam("sid") + "_" + Global.getParam("uid") + "_sc";
if (Cookies.get(ck) == null)
return 0;
var cart = eval('(' + Cookies.get(ck) + ')');
if (cart[did] == undefined)
return 0;
else
return cart[did].num;
};
//显示购物车的总数量和价格
ShoppingCart.displayTotal = function () {
var ck = Global.getParam("sid") + "_" + Global.getParam("uid") + "_sc";
if (Cookies.get(ck) == null)
return "数量:0,金额:¥0";
var cart = eval('(' + Cookies.get(ck) + ')');
return "数量:" + cart["TotalCount"] + ",金额:¥" + cart["TotalMoney"];
};
基于Cookie的购物车的更多相关文章
- 基于Cookie的SSO登录分析和实现
什么是SSO? 现在很多大的互联网公司都会有很多的应用,比如以下是淘宝网的截图: 天猫 聚划算 头条等都是不同的应用,有的甚至采用完全不同的域名,但是所有在淘宝注册的用户都是使用的一套用户名和口令,如 ...
- 浏览器禁用Cookie,基于Cookie的会话跟踪机制失效的解决的方法
当浏览器禁用Cookies时.基于Cookie的会话跟踪机制就会失效.解决的方法是利用URL重写机制跟踪用户会话. 在使用URL重写机制的时候须要注意.为了保证会话跟踪的正确性,全部的链接和重定向语句 ...
- 【JSP】Cookie的使用及保存中文,并用Cookie实现购物车功能
Cookie是服务器存放在客户端的一些数据,比如密码,以及你曾经访问过的一些数据. 设置Cookie //设置cookie Cookie cookie = new Cookie("TOM&q ...
- nginx第三方模块---nginx-sticky-module的使用(基于cookie的会话保持)
目前的项目网站架构中使用了F5和nginx,F5用来做负载均衡,nginx只用作反向代理服务器.最近应客户的要求准备去掉F5,使用软负载.大家都知道nginx抗并发能力强,又可以做负载均衡,而且使用n ...
- Asp.Net Core 2.0 项目实战(10) 基于cookie登录授权认证并实现前台会员、后台管理员同时登录
1.登录的实现 登录功能实现起来有哪些常用的方式,大家首先想到的肯定是cookie或session或cookie+session,当然还有其他模式,今天主要探讨一下在Asp.net core 2.0下 ...
- 使用nginx sticky实现基于cookie的负载均衡
在多台后台服务器的环境下,我们为了确保一个客户只和一台服务器通信,我们势必使用长连接.使用什么方式来实现这种连接呢,常见的有使用nginx自带的ip_hash来做,我想这绝对不是一个好的办法,如果前端 ...
- (26)基于cookie的登陆认证(写入cookie、删除cookie、登陆后所有域下的网页都可访问、登陆成功跳转至用户开始访问的页面、使用装饰器完成所有页面的登陆认证)
获取cookie request.COOKIES['key'] request.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age ...
- Asp.Net Core基于Cookie实现同域单点登录(SSO)
在同一个域名下有很多子系统 如:a.giant.com b.giant.com c.giant.com等 但是这些系统都是giant.com这个子域. 这样的情况就可以在不引用其它框架的情况下, ...
- 使用nginx sticky实现基于cookie的负载均衡【转】
在多台后台服务器的环境下,我们为了确保一个客户只和一台服务器通信,我们势必使用长连接.使用什么方式来实现这种连接呢,常见的有使用nginx自带的ip_hash来做,我想这绝对不是一个好的办法,如果前端 ...
随机推荐
- 【转】在一个Job中同时写入多个HBase的table
在进行Map/Reduce时,有的业务需要在一个job中将数据写入到多个HBase的表中,下面是实现方式. 原文地址:http://lookfirst.com/2011/07/hbase-multit ...
- 精确光源(Punctual Light Sources)
<Physically-Based Shading Models in Film and Game Production>(SIGGRAPH 2010 Course Notes) (地址: ...
- unity, 立即生效动画:Animation.sample()
在调用了动画播放之后,动画并不会立即应用(骨骼Transform并不会立即改变),最快也要等到本帧lateUpdate才能生效. 如果有特殊需求,希望在调用了动画播放之后立即生效,则可以紧接着调一句A ...
- Spring Security教程(三):自定义表结构
在上一篇博客中讲解了用Spring Security自带的默认数据库存储用户和权限的数据,但是Spring Security默认提供的表结构太过简单了,其实就算默认提供的表结构很复杂,也不一定能满足项 ...
- 使用Method swizzling (也就是运行时交换两个方法的imp ,实现重写方法)
贴上资源.很简单 https://gist.github.com/rudyjahchan/2191796 http://itony.me/592.html http://stackoverflow.c ...
- sql 优化 -- sql中的自定函数
Long run sql: MERGE INTO INTITMRTNPARAM D USING ( SELECT A.INRFILENM,A.INRSTAT,A.INRDEPCD,A.INRITMCD ...
- ace admin后台模板
http://ace.jeka.by/index.html 下载: http://www.daimajiayuan.com/plus/download.php?open=0&aid=18152 ...
- Java经典问题:传值与传引用?
转自:http://developer.51cto.com/art/201104/254715.htm Java到底是传值还是传引用?相信很少有人能完全回答正确.通常的说法是:对于基本数据类型(整型. ...
- 菜鸟学Java(十六)——Jboss简介
简介 JBoss是全世界开发者共同努力的成果,一个基于J2EE的开放源代码的应用服务器. 因为JBoss代码遵循LGPL许可,可以在任何商业应用中免费使用它,而不用支付费用.2006年,Jboss公司 ...
- lua -- io.pathinfo
io.pathinfo 拆分一个路径字符串,返回组成路径的各个部分. 格式: parts = io.pathinfo(路径) 使用示例: local pathinfo = io.pathinfo(&q ...