原生js+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>

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

以上是 原生js+cookie实现购物车功能的方法分析 的全部内容, 来源链接: utcz.com/z/344667.html

回到顶部