基于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来做,我想这绝对不是一个好的办法,如果前端 ...
随机推荐
- Spring JavaConfig
以前,Spring推荐使用XML的方式来定义Bean及Bean之间的装配规则,但是在Spring3.0之后,Spring提出的强大的JavaConfig这种类型安全的Bean装配方式,它基于Java代 ...
- [转]理解java的三大特性之多态
java提高篇(四)-----理解java的三大特性之多态 面向对象编程有三大特性:封装.继承.多态. 封装隐藏了类的内部实现机制,可以在不影响使用的情况下改变类的内部结构,同时也保护了数据.对外 ...
- mysql-8.0.11 比较坑的地方dba门要淡定
[事件描述] 突然之间大量的连接进入数据库.并放开手干,这个使得mysql使用了大量的内存,触发了linux的oom机制.然后mysql就这样 被linux给干掉了.没错MySQL宕机了,要相信我说的 ...
- SQL SERVER 数据库被标记为“可疑”的解决办法
问题背景: 日常对Sql Server 2005关系数据库进行操作时,有时对数据库(如:Sharepoint网站配置数据库名Sharepoint_Config)进行些不正常操作如数据库在读写时而无故停 ...
- vuex入门教程和思考
Vuex是什么 首先对于vuex是什么,我先引用下官方的解释. Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可 ...
- IBAction:IBOutlet:注意事项
1.IBAction: 1> 能保证方法能够连线 > 相当于void 2.IBOutlet: 1> 能保证属性能够连线 3.常见错误 setValue:forUndefinedKey ...
- FFmpeg(9)-解码器解码代码演示(FFmpeg调用MediaCodec实现硬解码、多线程解码、及音视频解码性能测试)
一.AVFrame 用来存放解码后的数据. [相关函数] AVFrame *frame = av_frame_alloc(); // 空间分配,分配一个空间 ...
- DOUHAO
https://www.java-forums.org/new-java/42610-java-regular-expressions-comma-seperated-list.html https: ...
- FLINK 案例分析
基于Flink流处理的动态实时超大规模用户行为分析 https://zhuanlan.zhihu.com/p/31548501 基于Flink流处理的动态实时超大规模用户行为分析 https://zh ...
- 破解AI大脑黑盒迈出新一步!谷歌现在更懂机器,还开源了研究工具
https://zhuanlan.zhihu.com/p/34306323 https://distill.pub/2018/building-blocks/