IT实战联盟博客:http://blog.100boot.cn

上一篇:微信小程序微商城(七):动态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;    // 商品总数量-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实战联盟博客:http://blog.100boot.cn

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

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

    看效果web 购物车.gif小程序 开发计划微信小程序 一.商品详情页将商品信息放入缓存 二.购物车页面读取缓存获取商品信息 三.购物车商品计算和删除缓存商品 1.商品详情页将商品信息放入缓存数组 d ...

  2. 微信小程序微商城(九):微信授权并实现个人中心页面页面

    IT实战联盟博客:http://blog.100boot.cn 上一篇:微信小程序微商城(八):缓存实现商品购物车功能 看效果 开发计划 1.实现微信授权并获取用户信息 2.个人中心页面布局 一.实现 ...

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

    IT实战联盟博客:http://blog.100boot.cn 上一篇:微信小程序微商城(四):动态API实现商品详情页(上) 看效果 加入购物车.gif 开发计划 1.加入购物车悬浮框.商品数量.价 ...

  4. 免费的小程序微商城系统它不香吗?

    互联网市场更新迭代很快,基本5年左右就能完成一个周期的技术升级,这不,微信小程序微商城系统刚火不久,现在市面上很多类似系统就开始宣传永久免费使用了.这是为什么呢,他们没有成本吗?他们不想赚钱吗?现在我 ...

  5. 分析:很多小程序微商城系统为什么敢永久免费使用

    互联网市场更新迭代很快,基本5年左右就能完成一个周期的技术升级,这不,微信小程序微商城系统刚火不久,现在市面上很多类似系统就开始宣传永久免费使用了.这是为什么呢,他们没有成本吗?他们不想赚钱吗?现在我 ...

  6. 搭建公众号微商城+小程序微商城 企业商城系统一条龙 拖拽可视化装修模板

    搭建公众号微商城+小程序微商城 企业商城系统一条龙 拖拽可视化装修模板 来源:廖万里的博客  www.kkkliao.cn 本程序需有认证服务号!或者认证小程序 微信支付走官方接口! 没有的话 自己准 ...

  7. 微信小程序 本地mysql_微信小程序系列之使用缓存在本地模拟服务器数据库

    微信小程序系列之使用缓存在本地模拟服务器数据库 现在将data.js这个文件视作是本地数据库的初始化数据,要做的第一件事就是讲这些初始化数据装进缓存中,以形成数据库的初始化数据 整个应用程序的生命周期 ...

  8. 小程序微商城 解决方案

    想找个能把项目当成自己事业 能够呕心沥血,加班加点也要把任务做到完美的一个产品经理?产品经理表示要配置多少个技术开发? 市场调研 市场调研是指研究市场以了解客户需求.竞争状况及市场力量(market ...

  9. 微信小程序与内嵌网页交互实现支付功能

    上个月,小程序开放了新功能,支持内嵌网页,所以我就开始了小程序内嵌网页之路,之前我只是个小安卓. 内嵌网页中可使用JSSDK 1.3.0提供的接口,可坑就来了,居然不支持支付接口的调用,经过一番研究, ...

最新文章

  1. 如何修改Exchange邮件报警信息
  2. linux tf命令,Linux系统命令介绍之vmstat命令详解
  3. php变量值随机,PHP生成各类随机数值
  4. 【转】data和attr的用法与区别
  5. Dapr 客户端 搭配 WebApiClientCore 玩耍服务调用
  6. 李宏毅《机器学习》完整版笔记发布
  7. python module
  8. 浏览——用户自定义路径
  9. centos mysql开发包_CentOS 7 安装 MySQL-阿里云开发者社区
  10. 跟燕十八学习PHP-第二十八天-union用法深入讲解
  11. 这个“达芬奇”不一般!它是美国医生的好帮手
  12. MySQL DBLE_MySQL 中间件 - DBLE 简单使用
  13. 5大关键,让你二十年后依然是人才
  14. php远程控制代码,内部网络机器的远程控制软件UltraVNC及其源代码
  15. 达索系统引领数字化的五个时代
  16. 学了C语言,能开发什么项目?
  17. pwm电机调速的原理介绍与代码实现
  18. MIDI通信协议(翻译)
  19. 继续谈谈从Rxjava迁移到Flow的背压策略
  20. c语言版数据结构期末考试试题及答案,数据结构c语言版期末考试复习试题[1]

热门文章

  1. 云展网教程 | 为什么下载下来的EXE文件打不开?
  2. mybatis超详细的笔记记录
  3. MySQL安装配置教程-win10
  4. 全盘扫描是怎么实现的
  5. 用ASP.NET_Regsql.exe创建Session数据库
  6. 对不起,我不再爱你了
  7. 300集java课程详细介绍
  8. 基于相移法的结构光三维测量技术
  9. 机票预订系统活动图_机票预订系统(概要设计说明书)
  10. 想学SEM培训就来找网优谷