1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 微信小程序微商城(八):缓存实现商品购物车功能

微信小程序微商城(八):缓存实现商品购物车功能

时间:2018-07-21 07:45:27

相关推荐

微信小程序微商城(八):缓存实现商品购物车功能

IT实战联盟博客:

上一篇:微信小程序微商城(七):动态API实现商品分类

看效果

购物车.gif

开发计划

1、商品详情页将商品信息放入缓存2、购物车页面读取缓存获取商品信息3、购物车商品计算和删除缓存商品

一、商品详情页将商品信息放入缓存

detail.wxml

<button data-goodid="{{goods.goodsId}}" class="button-addCar" bindtap="addCar" formType="submit">确定</button>

绑定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) + '...';} // 获取购物车的缓存数组(没有数据,则赋予一个空数组) var arr = wx.getStorageSync('cart') || []; 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('cart', arr)} catch (e) {console.log(e)}//关闭窗口wx.showToast({title: '加入购物车成功!',icon: 'success',duration: 2000});this.closeDialog();// 返回(在if内使用return,跳出循环节约运算,节约性能) return;}} // 遍历完购物车后,没有对应的item项,把goodslist的当前项放入购物车数组 arr.push(goods);} else {arr.push(goods);} // 最后,把购物车数据,存放入缓存 try {wx.setStorageSync('cart', arr) // 返回(在if内使用return,跳出循环节约运算,节约性能) //关闭窗口wx.showToast({ title: '加入购物车成功!', icon: 'success', duration: 2000}); this.closeDialog(); return;} catch (e) { console.log(e)}}

二、购物车页面读取缓存获取商品信息

cart.wxml

<view class="J-shopping-cart-empty" hidden="{{iscart}}"><view class="shopping-cart-empty"><view class="bg"></view> <view class="cart"></view><text class='empty-text'>购物车空空如也</text> <p></p><navigator url="/pages/goods/goods"><a href="//" class="button button-primary" >去抢购 </a></navigator></view></view> <view class="scroll" hidden="{{hidden}}"><scroll-view class="scroll" scroll-y="true"><view class="separate"></view><view wx:for="{{carts}}"><view class="cart_container"> <view wx:if="{{!item.isSelect}}"><icon class="item-select" bindtap="switchSelect" data-index="{{index}}" data-id="{{index}}" type="circle" size="20"></icon></view><view wx:elif="{{item.isSelect}}"><icon class="item-select" bindtap="switchSelect" data-index="{{index}}" data-id="{{index}}" type="success" color="#f0145a" size="20"></icon></view><image class="item-image" src="{{item.imgUrl}}"></image><import src="../template/template.wxml" /><view class="column"><text class="title">{{item.title}}</text><image bindtap="delGoods" id="img{{index}}" data-index="{{index}}" src="../../images/del.png"></image> <view class="row"><text class="sku-price">¥{{item.price * item.count}}</text><view class="sku"><template is="quantity" data="{{ ...item,index:index}}" /> </view></view></view></view><view class="separate"></view></view></scroll-view></view><view class="bottom_total" hidden="{{hidden}}"><view class="bottom_line"></view><view class="row"><view wx:if="{{!isAllSelect}}"><icon class="item-allselect" bindtap="allSelect" type="circle" size="20"></icon></view><view wx:elif="{{isAllSelect}}"><icon class="item-allselect" bindtap="allSelect" type="success" color="#f0145a" size="20"></icon></view><text class="small_text">全选</text><text>合计:¥ </text><text class="price">{{totalMoney}}</text><button class="button-red" bindtap="toBuy" formType="submit">去结算 </button></view></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;} .cart_container { display: flex; flex-direction: row; background-color: #FFFFFF; margin-bottom: 10rpx;}.scroll { margin-bottom: 120rpx; }.column { display: flex; flex-direction: column;}.row { display: flex; flex-direction: row; align-items: center;}.sku { margin-left: 100rpx; position: absolute; right: 30rpx; margin-top: 30rpx; }.sku-price { color: red; position: relative; margin-top: 30rpx; }.price { color: red; position: relative;}.title { font-size: 32rpx; margin-top: 40rpx;}.small_text { font-size: 28rpx; margin-right: 40rpx; margin-left: 25rpx;}.item-select { width: 40rpx; height: 40rpx; margin-top: 90rpx; margin-left: 20rpx;}.item-allselect { width: 40rpx; height: 40rpx; margin-left: 20rpx; margin-top:25rpx; }.item-image { width: 180rpx; height: 180rpx; margin: 20rpx;} .bottom_line { width: 100%; height: 2rpx; background: lightgray;} .bottom_total { position: fixed; display: flex; flex-direction: column; bottom: 0; width: 100%; height: 120rpx; line-height: 120rpx; 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('cart') || []; 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: '去结算', icon: 'success', duration: 3000}); this.setData({ showDialog: !this.data.showDialog});}, //数量变化处理handleQuantityChange(e) { var componentId = ponentId; 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; // 商品总数量-1if (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('cart', this.data.carts); this.priceCount();} else { this.setData({cart: this.data.carts, iscart: false, hidden: true,})wx.setStorageSync('cart', []);}}

备注

微信小程序微商城系列 都是通过https 动态获取数据并展示的,建议从第一篇开始阅读。大家多多支持本系列文章会继续更新下去,谢谢各位!大家在使用过程中有哪些建议可以提出来,我们一起学习哈~~~

微信小程序微商城系列

微信小程序微商城:开发者key获取

微信小程序微商城(一):https框架搭建并实现导航功能

微信小程序微商城(二):电商首页轮播、分类导航和新品特卖实现

微信小程序微商城(三):电商首页福利专场无限下拉刷新动态API数据实现

微信小程序微商城(四):动态API实现商品详情页(上)

微信小程序微商城(五):动态API实现商品详情页(下)

微信小程序微商城(六):动态API实现新品特卖商品流式布局

微信小程序微商城(七):动态API实现商品分类

关注我们

如果需要源码可以关注“IT实战联盟”公*众*号并留言(微商城源码,5个字会收到源码下载地址,一定要看源码里面的操作手册会少走很多弯路),也可以加入交流群和作者互撩哦~~~

IT实战联盟博客:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。