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

吃苹果的上帝 2018-07-16 16:55:45 ⋅ 753 阅读

上一篇:微信小程序微商城(七):动态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="//m.vip.com" 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 = 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('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实现商品分类

特别感谢

感谢katie 同学提供的购物车商品数量在微信开发工具上穿透效果bug和购物车删除商品页面布局。

关注我们

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


全部评论: 0

    我有话说:

    程序-template使用:实现购物商品数量加减功能

    上一篇我们实现购物功能,里面有用到template模板功能实现购物商品数量加减和价格计算功能......

    程序实现商品数量加减

    这是一个用程序原生代码实现的数量加减demo,主要是用于商品购物或者商品详情修改数量使用

    程序电商实战-商品详情加入购物(下)

    今天会接着上一篇开始写商品详情页加入购物的部分,直接看效果......

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

    加入购物悬浮框、商品数量、价格计算、收藏和加入购物功能开发

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

    程序商品分类页面布局并且调用动态API获取数据并加载

    程序商城(九):授权并实现个人中心页面页面

    实现商城授权并获取用户信息和个人中心页面布局

    程序电商实战-购物(下)

    我们继续接着昨天的购物写,主要把剩下的数量加减 template 模板、选中计算功能实现掉!

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

    1、实现商品详情页面布局(这篇实现3个模块,头部商品图片轮播、商品价格和商品描述、商品详情展示) 2、根据用户点击不同的商品请求API动态加载数据

    程序电商实战-购物(上)

    好久没更新程序电商实战的文章了,是因为最近一直做整体架构调整,一些准备工作也是比较耗费时间的。在这几天将会有新版的 程序电商教程推出.......

    程序电商实战-商品详情(上)

    先看一下今天要实现程序商品详情页吧!

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

    本文将带领大家搭建https的程序框架,并实现动态获取数据展示效果!

    程序实战篇:商品属性联动选择(案例)

    本期的程序实战篇来做一个电商网站经常用到的-商品属性联动选择的效果,素材参考了一点点

    程序电商实战-商品列表流式布局

    今天给大家分享一下程序商品列表的流式布局方式,根据文章内容操作就可以看到效果哦~~~

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

    实现新品特卖商品列表布局、调用动态API获取数据并加载和点击商品跳转商品详情

    程序-Image的widthFix属性和rpm尺寸的使用

    在做程序商品详情页,商品的详情是图片集合,渲染完成后发现图片加载的很不自然

    A3Mall v1.5.2 发布,免费开源的 PHP 程序商城系统

    项目介绍 A3Mall商城系统是基于ThinkPhp6.0+Vue开发的一套移动电商系统, 支持公众号商城、H5商城程序商城,支持多种营销活动,优惠劵、订单活动、团购、秒杀、会员特价、积分

    程序抖音实战-首页(上)

    你也可以用程序编写一个抖音

    程序电商实战-首页(下)

    上一篇:程序电商实战-首页(上)好了,上一期我们把首页搜索、导航栏和广告轮播给做完了,那么接下来会继续