微信小程序实现购物车代码实例详解


Posted in Javascript onAugust 29, 2019

其实购物车都是类似的实现方法,只不过小程序是有他的数据层和业务层,在这里把之前的做法记录一下,分享出来也希望能给需要的小伙伴带来参考价值在最开始的时候先从本地存储中获取购物车数据,因为我们会切换页面 在页面切换的过程中需要实时重新加载购物车的数据,所以我们把获取的方法写在onShow中,而不是onLoad中:

onShow: function () {
  const cart = wx.getStorageSync("cart");
  let address = wx.getStorageSync("address") ;
  console.log(address);
  this.setData({
   address, cart
  })
  this.loadCarts();
  this.countAll();
 }

点击按钮更改购物车的数量:

handleNumEdit(e) {
  const { operator, goodsid } = e.target.dataset;
  let { cart } = this.data;
  cart[goodsid].count += (+operator);
  if (cart[goodsid].count < 1) {
   cart[goodsid].count = 1;
   wx.showModal({
    title: '提示',
    content: '您确定要删除吗',
    showCancel: true,
    cancelText: '取消',
    cancelColor: '#000000',
    confirmText: '确定',
    confirmColor: '#3CC51F',
    success: (result) => {
     if (result.confirm) {
      delete cart[goodsid];
      this.loadCarts();
      this.countAll();
     } else {
     }
    }
   });
  } else if (cart[goodsid].count > cart[goodsid].goods_number) {
   cart[goodsid].count = cart[goodsid].goods_number;
   wx.showToast({
    title: '没有库存了',
    icon: 'none',
    duration: 1500,
    mask: true
   });
  }
  this.loadCarts();
  this.countAll();
 }

加载购物车数据的方法:

data: {
  cart: {},
  address: {},
  totalPrice: 0,
  categoryLength: 0,
  isAllChecked: true
 },

单个商品被选中时触发:

loadCarts() {
  let { cart } = this.data;
  let isAllChecked = true;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    const element = cart[key];
    if (!element.isChecked) {
     isAllChecked = false;
     break;
    }
   }
  }
  this.setData({
   cart,
   isAllChecked
  });
 },

全选和反选触发的事件:

handleItemChecked(e) {
  let { goodsid } = e.target.dataset;
  let { cart } = this.data;
  let { isChecked } = cart[goodsid];
  cart[goodsid].isChecked = !isChecked;
  let checkedLength = 0;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    if (cart[key].isChecked) {
     checkedLength++;
    }
   }
  }
  const isAllChecked = checkedLength == Object.keys(cart).length;
  this.countAll();
  this.setData({
   isAllChecked
  })
 },

点击结算时触发:

handleItemAllChecked() {
  let { isAllChecked } = this.data;
  let { cart } = this.data;
  isAllChecked = !isAllChecked;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    cart[key].isChecked = isAllChecked;
   }
  }
  this.setData({
   isAllChecked,
   cart
  })
  this.countAll();
 },

纯js代码,可能有一定小程序代码经验的会看得轻松一点。以上便可以实现在对购物车的商品进行加减和全选与反选,以及对商品进行数量合计并计算价格。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript类库的顶层对象名用户体验分析
Oct 24 Javascript
JavaScript 大数据相加的问题
Aug 03 Javascript
Javascript学习笔记-详解in运算符
Sep 13 Javascript
js arguments对象应用介绍
Nov 28 Javascript
javascript小数四舍五入多种方法实现
Dec 23 Javascript
jQuery+css实现图片滚动效果(附源码)
Mar 18 Javascript
jquery实现excel导出的方法
Apr 04 Javascript
基于豆瓣API+Angular开发的web App
Jan 02 Javascript
jquery插件jSignature实现手动签名
May 04 Javascript
BootStrap实现手机端轮播图左右滑动事件
Oct 13 Javascript
JS中闭包的经典用法小结(2则示例)
Dec 28 Javascript
javascript canvas实现雨滴效果
Jun 09 Javascript
vue图片加载失败时用默认图片替换的方法
Aug 29 #Javascript
vue 框架下自定义滚动条(easyscroll)实现方法
Aug 29 #Javascript
Angular8路由守卫原理和使用方法
Aug 29 #Javascript
Vue中的循环及修改差值表达式的方法
Aug 29 #Javascript
vue父子组件通信的高级用法示例
Aug 29 #Javascript
Elementui表格组件+sortablejs实现行拖拽排序的示例代码
Aug 28 #Javascript
JS中async/await实现异步调用的方法
Aug 28 #Javascript
You might like
通过PHP CLI实现简单的数据库实时监控调度
2009/07/01 PHP
检查php文件中是否含有bom的函数
2012/05/31 PHP
php图片上传类 附调用方法
2016/05/15 PHP
Yii框架ACF(accessController)简单权限控制操作示例
2019/04/26 PHP
Swoole扩展的6种模式深入详解
2021/03/04 PHP
javascript学习笔记(三)显示当时时间的代码
2011/04/08 Javascript
Jquery实现简单的动画效果代码
2012/03/18 Javascript
js中typeof的用法汇总
2013/12/12 Javascript
jQuery圆形统计图开发实例
2015/01/04 Javascript
JQuery插件Quicksand实现超炫的动画洗牌效果
2015/05/03 Javascript
微信小程序-消息提示框实例
2016/11/24 Javascript
jQuery实现立体式数字动态增加(animate方法)
2016/12/21 Javascript
在Vue中使用echarts的实例代码(3种图)
2017/07/10 Javascript
jQuery remove()过滤被删除的元素(推荐)
2017/07/18 jQuery
在一般处理程序(ashx)中弹出js提示语
2017/08/16 Javascript
一文让你彻底搞清楚javascript中的require、import与export
2017/09/24 Javascript
JavaScript创建对象方法实例小结
2018/09/03 Javascript
关于vue路由缓存清除在main.js中的设置
2019/11/06 Javascript
js中关于Blob对象的介绍与使用
2019/11/29 Javascript
Vue实现简单计算器
2021/01/20 Vue.js
[40:19]2018完美盛典CS.GO表演赛
2018/12/17 DOTA
Python中使用Beautiful Soup库的超详细教程
2015/04/30 Python
Python字典简介以及用法详解
2016/11/15 Python
python实现随机梯度下降法
2020/03/24 Python
解决Jupyter因卸载重装导致的问题修复
2020/04/10 Python
在python中求分布函数相关的包实例
2020/04/15 Python
Python使用Selenium实现淘宝抢单的流程分析
2020/06/23 Python
Lacoste美国官网:经典POLO衫品牌
2016/10/12 全球购物
结婚喜宴主持词
2014/03/14 职场文书
C++程序员求职信范文
2014/04/14 职场文书
小学生环保标语
2014/06/13 职场文书
婚庆答谢词
2015/01/04 职场文书
《圆的周长》教学反思
2016/02/17 职场文书
MySQL中你可能忽略的COLLATION实例详解
2021/05/12 MySQL
vue elementUI表格控制对应列
2022/04/13 Vue.js
MySQL批量更新不同表中的数据
2022/05/11 MySQL