本篇文章给大家带来的内容是关于微信小程序商城开发之实现商品加入购物车的功能(代码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
看效果
购物车.gif
开发计划
1、商品详情页将商品信息放入缓存
2、购物车页面读取缓存获取商品信息
3、购物车商品计算和删除缓存商品
一、商品详情页将商品信息放入缓存
detail.wxml
button data-goodid= {{goods.goodsId}} >绑定bindtap事件将商品加入购物车。
detail.js
/** * 加入购物车 addCar: function (e) { var goods = this.data.goods; goods.isSelect=false; var count = this.data.goods.count; var title = this.data.goods.title; if (title.length 13) { goods.title = title.substring(0, 13) + #39;... #39;; // 获取购物车的缓存数组(没有数据,则赋予一个空数组) var arr = wx.getStorageSync( #39;cart #39;) || []; console.log( arr,{} , arr); if (arr.length 0) { // 遍历购物车数组 for (var j in arr) { // 判断购物车内的item的id,和事件传递过来的id,是否相等 if (arr[j].goodsId == goodsId) { // 相等的话,给count+1(即再次添加入购物车,数量+1) arr[j].count = arr[j].count + 1; // 最后,把购物车数据,存放入缓存(此处不用再给购物车数组push元素进去,因为这个是购物车有的,直接更新当前数组即可) try { wx.setStorageSync( #39;cart #39;, arr) } catch (e) { console.log(e) //关闭窗口 wx.showToast({ title: #39;加入购物车成功! #39;, icon: #39;success #39;, duration: 2000 }); this.closeDialog(); // 返回(在if内使用return,跳出循环节约运算,节约性能) return; // 遍历完购物车后,没有对应的item项,把goodslist的当前项放入购物车数组 arr.push(goods); } else { arr.push(goods); // 最后,把购物车数据,存放入缓存 try { wx.setStorageSync( #39;cart #39;, arr) // 返回(在if内使用return,跳出循环节约运算,节约性能) //关闭窗口 wx.showToast({ title: #39;加入购物车成功! #39;, icon: #39;success #39;, duration: 2000 }); this.closeDialog(); return; } catch (e) { console.log(e) }二、购物车页面读取缓存获取商品信息
cart.wxml
view >cart.wxss
@import ../template/template.wxss page{ background: #f3f4f5; /* font-size: 37.5px; */ .column image { width:33rpx; height:35rpx; display:inline-block; overflow:hidden; float:right; margin-top: -40rpx; margin-left:400rpx; .J-shopping-cart-empty{ margin: 0; padding: 0; border: 0; font: inherit; font-size: 100%; vertical-align: baseline; .shopping-cart-empty { height: 250px; padding-top: 3.2rem; padding-bottom: 1.6rem; background-color: #fff; text-align: center; position: relative; .shopping-cart-empty .bg{ position: absolute; width: 16.29333rem; height: 6.73333rem; background: transparent url(); left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); background-size: 100%; top: 0; .shopping-cart-empty .cart{ width: 5.83333rem; height: 7.46rem; background: transparent url() no-repeat; background-size: 100%; margin: 0 auto; .shopping-cart-empty .button { width: 8.46667rem; height: 1.5rem; display: block; margin: 20rpx auto; .empty-text { font-size: .64667rem; color: #222; margin-top: .53333rem; line-height: .74667rem; font-weight: 400; .button-primary { border: 1px solid #de3c96; color: #de3c96; text-decoration: none; text-align: center; display: block; border-radius: .21267rem; line-height: 1.5rem; -webkit-appearance: none; background: none; padding: 0 .26667rem; margin: 0; white-space: nowrap; position: relative; text-overflow: ellipsis; font-size: .74333rem; font-family: inherit; cursor: pointer; user-select: none;background: white; /* margin-top: 300rpx; */ border-top: 1rpx solid #ccc; z-index: 99; .button-red { background-color: #f0145a; position: fixed; right: 0; color: white; text-align: center; display: inline-block; font-size: 30rpx; border-radius: 0rpx; width: 30%; height: 120rpx; line-height: 120rpx; /* border: 1rpx solid #ccc; */ }
cart.js
/** * 页面的初始数据 data: { carts: [], //数据 iscart: false, hidden: null, isAllSelect: false, totalMoney: 0, onShow: function () { // 获取产品展示页保存的缓存数据(购物车的缓存数组,没有数据,则赋予一个空数组) var arr = wx.getStorageSync( #39;cart #39;) || []; console.info( 缓存数据: +arr); // 有数据的话,就遍历数据,计算总金额 和 总数量 if (arr.length 0) { // 更新数据 this.setData({ carts: arr, iscart: true, hidden: false }); console.info( 缓存数据: + this.data.carts); }else{ this.setData({ iscart: false, hidden: true, },三、购物车商品计算和删除缓存商品
cart.js
//勾选事件处理函数 switchSelect: function (e) { // 获取item项的id,和数组的下标值 var Allprice = 0, i = 0; let id = e.target.dataset.id, index = parseInt(e.target.dataset.index); this.data.carts[index].isSelect = !this.data.carts[index].isSelect; //价钱统计 if (this.data.carts[index].isSelect) { this.data.totalMoney = this.data.totalMoney + (this.data.carts[index].price * this.data.carts[index].count); } else { this.data.totalMoney = this.data.totalMoney - (this.data.carts[index].price * this.data.carts[index].count); //是否全选判断 for (i = 0; i this.data.carts.length; i++) { Allprice = Allprice + (this.data.carts[index].price * this.data.carts[index].count); if (Allprice == this.data.totalMoney) { this.data.isAllSelect = true; } else { this.data.isAllSelect = false; this.setData({ carts: this.data.carts, totalMoney: this.data.totalMoney, isAllSelect: this.data.isAllSelect, //全选 allSelect: function (e) { //处理全选逻辑 let i = 0; if (!this.data.isAllSelect) { this.data.totalMoney = 0; for (i = 0; i this.data.carts.length; i++) { this.data.carts[i].isSelect = true; this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count); } else { for (i = 0; i this.data.carts.length; i++) { this.data.carts[i].isSelect = false; this.data.totalMoney = 0; this.setData({ carts: this.data.carts, isAllSelect: !this.data.isAllSelect, totalMoney: this.data.totalMoney, }, // 去结算 toBuy() { wx.showToast({ title: #39;去结算 #39;, icon: #39;success #39;, duration: 3000 }); this.setData({ showDialog: !this.data.showDialog }, //数量变化处理 handleQuantityChange(e) { var componentId = e.componentId; var quantity = e.quantity; this.data.carts[componentId].count.quantity = quantity; this.setData({ carts: this.data.carts, /* 减数 */ delCount: function (e) { var index = e.target.dataset.index; console.log( 刚刚您点击了加一 var count = this.data.carts[index].count; // 商品总数量-1 if (count 1) { this.data.carts[index].count--; // 将数值与状态写回 this.setData({ carts: this.data.carts }); console.log( carts: + this.data.carts); this.priceCount(); /* 加数 */ addCount: function (e) { var index = e.target.dataset.index; console.log( 刚刚您点击了加+ var count = this.data.carts[index].count; // 商品总数量+1 if (count 10) { this.data.carts[index].count++; // 将数值与状态写回 this.setData({ carts: this.data.carts }); console.log( carts: + this.data.carts); this.priceCount(); priceCount: function (e) { this.data.totalMoney = 0; for (var i = 0; i this.data.carts.length; i++) { if (this.data.carts[i].isSelect == true) { this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count); this.setData({ totalMoney: this.data.totalMoney, /* 删除item */ delGoods: function (e) { this.data.carts.splice(e.target.id.substring(3),1); // 更新data数据对象 if (this.data.carts.length 0) { this.setData({ carts: this.data.carts wx.setStorageSync( #39;cart #39;, this.data.carts); this.priceCount(); } else { this.setData({ cart: this.data.carts, iscart: false, hidden: true, wx.setStorageSync( #39;cart #39;, []); }相关推荐:
微信小程序商城开发之动态API把商品进行分类(代码)
微信小程序商城开发之动态API实现特卖商品的流式布局代码
以上就是微信小程序商城开发之实现商品加入购物车的功能(代码)的详细内容,更多请关注php中文网其它相关文章!
微信app下载
微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!