基于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来做,我想这绝对不是一个好的办法,如果前端 ...
随机推荐
- 常用代码之八:setTimeout 和 clearTimeout。
1.先写一个错误的例子: function DealSomething() { //write some code window.setTimeout(function ...
- struts2 常量
struts.i18n.encoding 指定web应用的默认编码集
- iphone5刷机教程
如果不想麻烦可以在越狱之后添加源,cydia.china3gpp.com打ios7的补丁就可以了 机器为iphone5 美国sprint有锁版 1. 首先备份需要的程序和数据(把各种缓存的影片删掉再备 ...
- mongodb 远程访问配置
1.首先修改mongodb的配置文件 让其监听所有外网ip 编辑文件:/etc/mongodb.conf 修改后的内容如下: bind_ip = 0.0.0.0 port = 27017 auth=t ...
- talend 将hbase中数据导入到mysql中
首先,解决talend连接hbase的问题: 公司使用的机器是HDP2.2的机器,上面配置好Hbase服务,在集群的/etc/hbase/conf/hbase-site.xml下,有如下配置: < ...
- UITableView/UIScrollView 不能响应TouchBegin 的处理 及窥见 hitTest:withEvent:
重写touchBegin 方法是不行的,在UITableView/UIScrollView 解决方案 重写hitTest:withEvent: 在他们的子类中 - (UIView *)hitTest ...
- 关于 NSInvocation
Invocation 调用的意思. 可想而知NSInvocation 是一个 方法调用 封装的类. 这体现了 面向对象的思想, 及一切皆对象.函数也不例外. 一般编程中,应该很少用到这个. 但是 ...
- shiro 自定义过滤器,拦截过期session的请求,并且以ajax形式返回
自定义过滤器: public class CustomFormAuthenticationFilter extends FormAuthenticationFilter { @Override pro ...
- asp.net core在linux上的部署调试
双十一买了阿里云的LINUX服务器三年¥720 把自己的niunan.net一系列网站都部署上去 用jexus来部署,部署时发现头一个网站没问题,但是后一个网站部署就有问题..输入域名打不开,但JEX ...
- Atitit js es5 es6新特性 attilax总结
Atitit js es5 es6新特性 attilax总结 1.1. JavaScript发展时间轴:1 1.2. 以下是ES6排名前十的最佳特性列表(排名不分先后):1 1.3. Es6 支持情况 ...