问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

用JavaScript代码模拟购物车。

发布网友 发布时间:2022-04-21 13:57

我来回答

1个回答

热心网友 时间:2023-09-23 03:24


这篇文章主要介绍了原生js+cookie实现购物车功能的方法,结合实例形式分析了javascript结合cookie存储实现购物车功能的相关操作技巧,需要的朋友可以参考下
本文实例讲述了原生js+cookie实现购物车功能的方法。分享给大家供大家参考,具体如下:
这里使用js+cookie实现简单的购物车功能。
首先是简单的HTML结构,只是为了演示下功能。
<ul>
<li><span>a0001</span><span>shdfi</span><span>¥98.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0002</span><span>fbvfgdb</span><span>¥698.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0003</span><span>dfdfi</span><span>¥988.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0004</span><span>sssi</span><span>¥998.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0005</span><span>yyu</span><span>¥98.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0006</span><span>sheri</span><span>¥598.00</span>
<input type="button" value="加入购物车"></li>
<li><span>a0007</span><span>dsfcdhdfi</span><span>¥498.00</span>
<input type="button" value="加入购物车"></li>
<li><span>sbnm,</span><span>¥698.00</span><input type="button" value="加
入购物车"></li>
</ul>
<a href="购物车查看页面.html" rel="external nofollow" >查看购物车</a>下面的代码是实现点击添加按钮时,把商品信息加入cookie,注释比较详细,在代码中我把操作cookie(set和get封装为cookieUtil对象的方法,方便调用)。
<script>
//JSON.parse
//JSON.stringify
onload = function () {
var input = document.getElementsByTagName("input");
//判断是否存在cookie,或是第一次添加
var arr = cookieUtil.getCookie("car") ?
JSON.parse(cookieUtil.getCookie("car")) : [];
//遍历给每个input元素添加点击事件
for (var j = 0; j < input.length; j++) {
input[j].onclick = function () {
var g_id = this.parentNode.children[0].innerHTML;
var g_name = this.parentNode.children[1].innerHTML;
var g_price = this.parentNode.children[2].innerHTML;
//遍历cookie,判断是否已经存在该商品
for (var i = 0; i < arr.length; i++) {
if (arr[i].g_id == g_id) {
//已经存在该商品,商品数量+1
arr[i].num++;
break;//立即结束遍历
}
}
//如果i的值与arr长度相同,则证明遍历结束也没有进入过if条件语句,
//cookie中不存在该商品,新建一个商品对象,并添加到数组中
if (i == arr.length) {
var goods = {
"g_id" : g_id,
"g_name" : g_name,
"g_price" : g_price,
num : 1
}
arr.push(goods);
}
//把更新后的数组序列化为JSON字符串,保存到cookie中
var date = new Date();
date.setDate(date.getDate() + 10); //保存十天
//保存cookie
cookieUtil.setCookie("car", JSON.stringify(arr), date);
}
}
}
</script>这里是封装的cookieUtil对象
//cookie Util
var cookieUtil = {
//添加cookie
setCookie: function (name, value, expires) {
var cookieText = encodeURIComponent(name) + "=" +
encodeURIComponent(value);
if (expires && expires instanceof Date) {
cookieText += "; expires=" + expires;
}
// if (domain) {
// cookieText += "; domain=" + domain;
// }
document.cookie = cookieText;
},
//获取cookie
getCookie: function (name) {
var cookieText = decodeURIComponent(document.cookie);
var cookieArr = cookieText.split("; ");
for (var i = 0; i < cookieArr.length; i++) {
var arr = cookieArr[i].split("=");
if (arr[0] == name) {
return arr[1];
}
}
return null;
},
//删除cookie
unsetCookie: function (name) {
document.cookie = encodeURIComponent(name) + "=; expires=" +
new Date(0);
}
};上面的代码都非常好理解,下面这个页面就是把cookie中的商品信息取出来。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>查看购物车页面</title>
<script src="../Utils.js"></script>
<script>
onload = function () {
var ul = document.getElementsByTagName("ul")[0];
var arr = cookieUtil.getCookie("car");
if (arr) {
arr = JSON.parse(arr);
//存在cookie则取出来显示到页面上
for (var i = 0; i < arr.length; i++) {
//每个数组元素对应的是一个商品对象
var goods = arr[i];
var li = document.createElement("li");
li.innerHTML = "商品名称:" + goods.g_name + ",商品数
量" + goods.num + ",商品单价:" + goods.g_price;
ul.appendChild(li);
}
} else {
alert("购物车中还不存在商品!");
}
}
</script>
</head>
<body>
<ul></ul>
</body>
</html>上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
在Angular中如何实现敏感文字提示
在Angular中如何实现隐藏显示
在js中如何实现图片左右滑动
BrowserRouter如何配合react-router服务器
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
四开大门要多少宽度 四开大门尺寸多少 大门四开门尺寸是多少 秦昊新剧《亲爱的小孩》网上褒贬不一,你觉得这部剧是否符合现实呢? 《亲爱的小孩》妻子产后失禁,丈夫嫌弃反复洗手,你怎么看? 求推荐一个安卓手机文档管理工具吧,手机实在太乱了,也没有介绍的? 手机文件管理器哪个好用 隐私文件夹app哪个好用 泰山茶年产600吨品牌近40个销售额达5亿元 山东茶叶品牌 山东茶叶厂家 山东有哪些茶叶品牌【品牌库】 从广延路到真如中学如何走? 用JavaScript代码模拟购物车。 3D技术有哪些应用? 3D技术有哪些应用? 前端开发需要学习什么计算机语言,难不难? 前端开发需要学习什么计算机语言,难不难? 前端都学什么框架? 前端都学什么框架? 零基础学习Web 前端,求大神指点,该如何下手?谢谢! 零基础学习Web 前端,求大神指点,该如何下手?谢谢! vue elementUI -- table的任意列合计功能 vue购物车出现了一个bug,一个单选按钮取消选中,为啥全部按钮包括全选按钮都取消选中了? 怎么可以找到黑名单的联系人 华为畅享9抖音怎么设为视频来电铃声 华为mate40pro抖音来电铃声怎么设置? 怎样激活iPhone11? 快手发作品为什么在同城下面 不是刚发在置顶吗 - 信息提示 永艺的毕加索产品怎么样? 毕加索的原名是什么? 【毕加索ps917钢笔怎么样】 现在学web前端开发前景好不好? 现在学web前端开发前景好不好? 英国留学 去英国留学有什么好玩的地吗 英国留学 去英国留学有什么好玩的地吗 听说Java和web学的东西基本一样,是这样的吗? 听说Java和web学的东西基本一样,是这样的吗? GMAT考试报名可以使用支付宝支付吗? GMAT考试报名可以使用支付宝支付吗? 女生学前端好还是Java好,求推荐 女生学前端好还是Java好,求推荐 各大公司对前端应届毕业生或者实习生的要求是怎样的? 各大公司对前端应届毕业生或者实习生的要求是怎样的? 哪些大学的电子商务比较好? 哪些大学的电子商务比较好? 市长是什么级别 市长什么级别 直辖市市长是什么级别? 直辖市市长和省长哪个大 直辖市市长是什么级别 经济特区的市长跟直辖市的市长谁级别大